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155. 

Products infringing: Any product using 
Microsoft Product Activation or Reader . 
Activation feature. * . 

A virtual distribution environment comprising 


(a) a first host processing environment 
comprising 

computer running a Microsoft product 
containing the Product Activation feature, 
including Windows XP, Office XP,.Visio 
■ 2002. Reader usinp its activation feature 

*vvv*uw* UvJAbC, J K+J Uwlfl V till vll IwitiiU Vt 

CD a central processing unit; 

CPU of comDUter 

(2) main memory operatively connected 
to said central processing unit: 

main memory of computer 

to said central processing unit and said 

main mpmnrv* 

licuu uibK or ouicr mass storage coniainea in 
computer 

fW\ co%A melee ctnmoP 1 ctnrino tamn^r rpcictnnt 

software designed to be loaded into said main 
memory and executed by said central 
processing unit, said tamper resistant software 
comnrisinf?" 

i f m O /"\ f~t Pt*rt/1ll/*t A ptnrotiAn o/-\"^h»T tire* 

jviicruboii r rouuci /\cuvauon soivware 

(1) machine check programming which 
derives information from one or more 
aspects of said host processing 
environment. 

Product Activation software generates 
hardware information relating to the host 
processing environment as part of the 
activation process 

(2) one or more storage locations 
storing said information; 

hardware information is stored in the 
computer's storage 

(3) integrity programming which 


(i) causes said machine check 
programming to derive said 
information, 

each time the Microsoft program starts up after 
initial activation, Product Activation checks 
the originally derived hardware information 
against current hardware 

(ii) compares said information 
to information previously stored 
in said one or more storage 
locations, and 

each time the Microsoft program starts up after 
initial activation, Product Activation checks 
the originally derived hardware information 
against current hardware 

(iii) generates an indication 
based on the result of said 
comparison: and 

Product Activation software indicates whether 
the test has passed or failed 

(4) programming which takes one or 
more actions based on the state of said 
indication: 


(i) said one or more actions 
including at least temporarily 
halting further processing. 

Product Activation software will allow system 
startup procedures to continue, if test succeeds, 
or discontinue startup and offer user 
opportunity to reactivate if the test fails 

' i! 
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156. 


A virtual distribution environment comprising 
(a) a first host processing environment 
comprising 


Product Infringing: Any product using 
Microsoft Product Activation or Reader 
Activation feature. 


computer running a Microsoft product 
containing the Product Activation feature, 
including Windows XP, Office XP, Visio 2002 
andReader 


(Ha central processing unit: 


CPU of computer 


(2) main memory operatively connected 
to said central processing unit: 


main memory of computer 


(3) mass storage operatively connected 
to said central processing unit and said 
main memory: . 


hard disk or other mass storage contained in 
computer 


^b) said mass. storage storing tamper resistant 
software designed to be loaded into said 
main memory and executed by said central 
processing unit, said tamper resistant 
software comprising: 


Microsoft Product Activation software 


(1) machine check programming which 
derives information from one or more 
aspects of said host processing 
environment . 


Product Activation software generates 
hardware information relating to the host 
processing environment as part of the 
activation process 


(2) one or more storage locations 
storing said information: 


hardware information is stored in the 
computer's storage 


(3) integrity programming which 


(i) causes said machine check 
programming to derive said 
information, 


each time the Microsoft program starts up after 
initial activation, Product Activation checks 
the originally derived hardware information 
against current hardware 


(ii) compares said information 
to information previously stored 
in said one or more storage 
locations, and 


each time the Microsoft program starts up after 
initial activationj Product Activation checks 
the originally derived hardware information 
against current hardware 


(iii) generates an indication 
based on the result of said 
comparison: and 


Product Activation software indicates whether 
the test has passed or failed 


(4) programming which takes one or 
more actions based on the state of said 
indication: 


(i) said one or more actions 
including at least temporarily 
disabling certain functions. 


Product Activation may/disable the underlying 
software from generating new files or running 
user applications if the test fails 


; i 
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157. 


A virtual distribution environment comprising 


(a) a first host processing environment 
' comprising 


(1) a central processing unit: 


(2) main memory operatively connected 
to said central processing unit: 


(3) mass storage operatively connected 
to said central processing unit and said 
main memory: 


(b) said mass storage storing tamper resistant 
software designed to be loaded into said 
main memory and executed by said central 
processing unit, said tamper resistant 
% software comprising: 


(1) machine check programming which 
derives information from one or more 
aspects of said host processing 
environment. 


(2) one or more storage locations 
storing said information: 


(3V integrity programming which 


(i) causes said machine check 
programming to derive said 
information, 


(ii) compares said information 
to information previously stored 
in said one or more storage 
locations, and 


(iii) generates an indication 
based on the result of said 
comparison: and 


(4) programming which takes one or 
more actions based on the state of said 
indication: 


(i) said one or more actions 
including displaying a message 
to the user. 


Product Infringing: Any product using 
Microsoft Product Activation or Reader 
Activation feature. 


computer running a Microsoft product 
containing the Product Activation feature, 
including Windows XP, Office XP, Visio 2002 
and Reader 


CPU of computer 


main memory of computer 


hard disk or other mass storage contained in 
computer 


Microsoft Product Activation software 


Product Activation software generates hash 
information relating to the host processing 
environment as part of the activation process 


hardware information is stored in the 
computer's storage . ' 


each time the Microsoft program starts up after 
initial activation, Product Activation checks 
th^ originally derived hardware information 
against current hardware 


each time the Microsoft program starts up after 
initial activation, Product Activation checks 
the originally derived hardware information 
against current hardware 


Product Activation software indicates whether 
the test has passed or failed 


Product Activation software displays a 
message to the user if the test fails 


.i! 
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Products infringing: Windows Media Player 


\ virtual distribution environment comprising 


i first host processing environment comprising 


WMP with Individualized DRM client 
(referred to hereafter as the Individualized 
WMP) running on a client computer 


t central processing unit 


Client CPU 


nain memory bperatively connected to said 
rentral processing unit 


Client memory 


nass storage operatively connected to said 
centra l processing unit and said main memory 


Local disk drive 


aid mass storage storing tamper resistant 
oftware designed to be loaded into said main 
tiemory and executed by said central 
►rocessing unit, said tamper resistant software 
omprising: 


Individualized WMP (I-WMP) stored on disk 
and loaded into main memory upon execution. 
I-WMP is tamper resistant. 


nachine check programming which derives 
nformation from one or more aspects of said 
ost processing environment, 


Individualization module is generated by the 
MS individualization service either when the 
un-individualized WMP tries to open licensed 
content that requires a security upgrade (aka, 
Individualization) or when the user requests an 
upgrade un-provoked. The individualization 
module is unique and signed and is bound to a 
unique hardware ID using the MS machine 
activation process. 


ne or more storage locations storing said 
iformation 


The aforementioned unique feature are located 
in multiple places or storage locations 


itegritv programming which 


auses said machine check programming to 
erive said information, 


The ID is regenerated by WMP/DRM client 
when first loading the Individualized DRM 
Client to access a piece of content requiring the 
security upgrade. 


smpares said information to information 
reviously stored in said one or more storage 
>cations« and ; 


The program checks the new copy against the 
one to which the individualized DRM client is 
bound. : 


enerates an indication based on the result of 
n'd comparison: and 


Program stores the result of this check. 


rogramming which takes one or more actions 
ased on the state of said indication 


If these are not equal, the user is notified via a 
message stating that he/she must acquire a 
security upgrade (that is, the current security 
upgrade is invalid). If they are equal then 
processing of songs requiring Individualization 
continues. ; ■ „ 


tid one or more actions including at least 
mporarilv disabling certain functions. 


Sonps targeted to this Individualization module 
cannot be accessed until the upgrade is correct. 
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4 II 157. A virtual distribution environment 
comprising 


Infringing products include: Windows Media 
Player ; : 


a first host processing environment comprising 


central processing unit 

I main memory operatively connected to said 
central processing unit 


See 156 


See 156 


See 156 


mass storage operatively connected to said 
central processing unit and said main memory 


See 156 


10 
11 
12 
13 
14 


15 


16 
17 
18 
19 
20 


said mass storage storing tamper resistant 
software designed to be loaded into said main 
memory and executed by said central 
processing unit, said tamper resistant software 
comprising: 


See 156 


machine check programming which derives 
information from one or more aspects of said 
host processing environment 


See 156 


one or more storage locations storing said 
1 information 


See 156 


integrity programming which causes said 
machine check programming to derive said 
information compares said information to 
information previously stored in said one or 
more storage locations, and 


See 156 


generates an indication based on the result of 
said comparison: and 


See 156 


programming which takes one or more actions 
I based on the state of said indication 


See 156 


said one or more actions including displaying a 
message to the user. 


If these are not equal, the user is notified via a 
message stating that he/she must acquire a 
security upgrade (that is, the current security 
upgrade is invalidV 


21 

22 
23 
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Infringing Product: Microsoft's Windows File 
Protection and System File Checker features, 
embodied in Microsoft's Windows 2000, 
Windows XP products, and Server 2003 


A virtual distribution environment comprising 


(a) a first host processing environment 
comprising 


computer running Microsoft Windows 2000 or 
Windows XP. 


(Da central processing unit: 

(2) main memory operatively connected 
to said central processing unit: 


CPU of computer 


main memory of comput er 


(3) mass storage operatively connected 
to said central processing unit and said 


main memory; 


hard disk or other mass storage contained in 
computer 


[b) said mass storage storing tamper resistant 
software designed to be loaded into said 
main memory and executed by said central 
processing unit, said tamper resistant 
software comprising: 


Windows File Protection process/service 
("WFP") and System File Checker (SFC.exe) 
features of winlogon.exe. Winlogon.exe is 
treated as a "critical" service by the Windows 
operating system. Files supporting WFP 
(including winlogon.exe, sfc.exe, sfc.dll (2000 
only), sfcfiles.dll (2000 only) and sfc_os.dll 
(XP only)) are "protected" files and are signed 
using a signature verified by a hidden key. In 
Windows 2000, WFP uses hidden functions 
within the sfc.dll libraiy. Functions are 
imported by "ordinal" instead of "name." 


(1) machine check programming which 
derives information from one or more 
aspects , of said host processing 
environment, 


(2) one or more storage locations 
storing said information: 

(3) integrity programming which 


Winlogon either directly or using another dll 
(XP) or using SFC.dll (2000) determines if 
changed file was protected, computes the hash 
of protected files and, if necessary, computes 
the hash of the file in the dll cache before using 
it to replace a file overwritten by an incorrect 
version of the file. 


hardware information is stored in the 
computer's memory 


(i) causes said machine check- 
programming to derive said 
information, 


Windows notifies Winlogon when there has 
been a system directory change or a change in 
the dll cache. 


(ii) compares said information 
to information previously stored 
in said one oi more storage 
locations, and 


Winlogon either directly or using another dll 
(XP) or using SFC.dll (2000) compares 
computed hash with hash in the hash database 
created from the Catalog file(s), and, if there is 
a difference, compares the hash of the file in 
the dll cache to the hash database created from 


!l 
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the Catalog file(s) before using it to replace an 
overwritten file. 


(iii) generates an indication 
based on the result of said 
comparison: and 


An event is written to the Event Viewer if 
hashes do not agree. 


(4) programming which takes one or 
more actions based on the state of said 
indication; - 


Depending on the circumstances, WFP 
displays several messages to the user, 
including prompting the user to contact the 
system administrator, and to insert a CD-ROM 


(i) said one or more actions 
including displaying a message 
to the user. 


See above. Messages also constitute viewable 
Event Property pop-ups. 
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Product Infringing: XBox 


A process comprising the following steps: 


The process constitutes assembly and use 
of components making up an XBox game. 


accessing a first record containing 
information directly or indirectly 
identifying one or more elements of a first 
component assembly, 


The first record consists of the second file 
table on an XBox DVD. This table ' 
identifies the .xbe file which includes the 
game information: 


at least one of said elements including at 
least some executable programming, 


The xbe file includes executable 
programming. 


at least one of said elements constituting a 
load module, 


The xbe file is a load module. 


said load module including executable 
programming and a header: 


The xbe file includes a header. 


at least a portion of said header is a public 
portion which is characterized by a 
relatively lower level of security 
protection: and 


Most information the xbe header is not 
obfuscated. 


at least a portion of said header is a private 
portion which is characterized, at least 
some of the time, by a level of security 
protection which is relatively higher than 
said relatively lower level of security 
protection. 


The entry point address and the kernel 
image thunk address listed in the xbe 
header are obfuscated and therefore at a 
higher level of security protection. 


jsing said information to identify and 
locate said one or more elements; . 


The second file table identifies the .xbe 
file, including where that file is located. 


accessing said located one or more 
dements: 


The .xbe file is accessed by the XBox. 


securely assembling said one or more 
elements to form at least a portion of said 
Irst component assembly; 


At runtime, the .xbe file is assembled with 
certain services of the operating system to 
form a component assembly. Security, 
associated with this assembling process 
includes verifying signatures associated 
with portions of the .xbe fi le, and replacing 
obfuscated calls to operating system 
services with actual addresses. 

The assembly may also include patch files 
downloaded from a remoie server. 


:xecuting at least some of said executable 1 Game plav requires execution of the 
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programmine: and 

assembled programming 

checking said record for validity prior to 
performing said executing step. 

The second* file table is protected by a 
digital signature, and is not loaded/used 
unless the digital signature is verified 
against the file. 

7. A process as in claim 6 in which: 


said relatively lower level of security 
protection comprises storing said public 
header portion in an unencrypted state; and 

The header is protected by the techniques 
protecting the xbe such as signing and 
security descriptors, but it is not encrypted 
except as noted below. 

said relatively higher level of security 
protection comprises storing said private 
header portion in an encrypted state. 

The entry point address and the kernel 
image thunk address listed in the xbe 
header are obfuscated. The Xbox SDK's 
(XDK) image build uses a key value shared 
with the retail XBox to perform two XOR 
operations against the addresses 
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Infringing products: Microsoft CLR or CCLR 
and .NET Framework SDK and products that 
include one or both of these. 


\ process comprising the following steps: 


a) accessing a first record containing 
nformation directly . or indirectly identifying 
me or more elements of a first component 
ssembly, 


The first record is either an assembly manifest, 
or a whole assembly; the elements are other \ 
assemblies that are referenced as external in 
the first record; the first component assembly 
is a .NET application domain: . 


(1) at least one of said elements 
including at least some executable 
programming, 


Assembly contains executable programming. 


(2) at least one of said elements 
constituting a load module. 


This is an external assembly referenced in the 
first record. _ 


(i) said load module including 
executable programming arid a 
header; 


Assemblies include executable programming, 
and the assembly manifest and CLS type 
metadata constitute a header. 


(ii) said header including an 
execution space identifier 
identifying at least one aspect of 
an execution space required for 
use and/or execution of the load 
module associated with said 
header; ■ 


This feature is provided for in the .NET 
architecture through numerous mechanisms, 
for example, by demands for ZonelD 
permissions. 


(iii) said execution space 
identifier provides the capability 
for distinguishing between 
execution spaces providing a 
higher level of security and 
execution spaces providing a 
lower level of security; 


SecurityZorie or other evidence provides this 
capability. 


)) using said information to identify and 
>cate said one or more elements; 


Manifest and type metadata information 
section is used to identify and locate files, code 
elements, resource elements, individual classes 
and methods. 


:) accessing said located one or more 
ements; 


Step carried out by the CLR or CCLR loader. 


I) securely assembling said one or more 
ements to form at least a portion of said first 
)mponent assembly; 


CLR or CCLR carries out this step, including 
checking the integrity of the load module, 
checking the load module's permissions, 
placing the load module contents into an 
application domain, isolating it from malicious 
or badly behaved code, and from code that 
does not have the permission to call it. 


) executing at least some of said executable 
oprammine: and 


Step carried but by the CLR/CCLR and the 
CLR/CCLR host. . 


■ HI 
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(f) checking said record for validity prior to 
performing said executing step. 


The CLR/CCLR checks the authenticity and 
the integrity of the first .NET assembly. 


9. A process as in claim 8 in which said 
execution space providing a higher level of 
security comprises a secure processing 
environment. • r. 


The CLR/CCLR constitutes a secure 
processing environment. 


13. A process as in claim 8 further comprising: 


(a) comparing said execution space identifier 
against information identifying the execution 
space in which said executing step is to occur; 
and 


In one example, the 

ZoneldentityPermissionAttribute SeciirityZone 
value demanded by control in the assembly 
manifest is compared against the Security Zone 
attribute value corresponding to the calling 
method ' 


(b) taking an action if said execution space 
identifier requires an execution space with a 
security level higher than that of the execution 
space in which said executing step is to occur. 


CLR/CCLR will throw an exception and* 
transfer control to an exception handler in the 
calling routine, or it will shut down the 
application if there is no such exception 
handler, if the permissions do not include the 
permissions required by the 
ZoneldentityPermissionAttribute. The 
ZoneldentityPermissions are hierarchical, 
unless customized. 


L4. A process as in claim 13 in which said 
iction includes terminating said process prior 
;o said executing step. 


CLR/CCLR may terminate the process or 
transfer control to an exception handler that 
may itself terminate the process. 


!l 
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Products infringing include Windows Installer 
SDK, and products that include the Windows 
Installer technology. 


A process comprising the following steps: 


Scenario 1 : use of Windows Installer packages 
(i.e. ,MSI files) to create Windows Installer- 
enabled applications, such as Office 2000 and 
used of the WI service to install them. 
Scenario 2: software distribution technologies 
that use the Windows Installer OS service for 
installation, such as Internet Component 
Download and products like Office Web 
Components. 

Either scenario can be used by SMS, 

IntelliMirror and third party tools like 

InstallShield and WISE. 

NT or later operating systems (because they 

use the subsystem identifier) 

using cabinet files, .CAB, (because they have a 

manifest and INF and/or OSD files), and 

have been signed with a digital signature and 

will be authenticated by Authenticode or 

WinVerifyTrust API and 

contain at least one PE (portable executables) 


i) accessing a first record containing 
lfoimation directly or indirectly identifying 
ne or more elements of a first component 
ssembly, 


Scenario 1 : First record is the .MSI file that 
contains information on what goes in the 
assembly and how to install the assembly. 

Scenario 2: 

A. First record is the cabinet manifest 
(indirect instructions) 

B. Or, First record can be INF and/or OSD 
files (direct instructions) 


(1) at least one of said elements 

including at least some executable 
programming, 


Both scenarios: The PE (portable executable) 
in the cabinet file is the executable 
programming. 


(2) at least one of said elements 
constituting a load module, 


Both scenarios: PE is a load module: 


(i) said load module including 
executable mogramming and a 


Both scenarios: The PE has several headers. 


i 
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header; 


(ii) said header including an 
execution space identifier 
identifying at least one aspect of 
an execution space required for 
use and/or execution of the load 
module associated with said 
header; 


Both scenarios: SUBS YTEM is a field in the 
PE Optional Header that is an executicm space 


(iii) said execution space 
identifier provides the capability 
for distinguishing between 
execution spaces providing a 
higher level of security and 
execution spaces providing a 
lower level of security; 


Both scenarios: SUBSYSTEM distinguishes 
between programs that can run in kernel mode 
and those that can run in user mode. This is a 
key security concept of process separation that 
was introduced with Windows NT. 

The Subsystem field in the PE header is used 
by the system to indicate whether the 
executable will run within Ring 3 (user mode)' 
6r use Ring 0 (native or kernel mode). 
Anything running in Ring 3 is limited to its 
own processing space. Executables running in 
Ring 0 can reach out to other spaces and have 
security measure built around them. 


>) using said information to identify and 
>cate said one or more elements; 


Scenario 1 : the MSI file identifies and locates 
the elements 

Scenario 2: 

.CAB manifest is used to identify Physical 
location 

OSD and/or INF is used to identify Logical 
location 


) accessing said located one or more 
ements; 


Scenario 1 : Using the MSI file 

Scenario 2: Using INF and/or OSD in cabinet 
file 


) securely assembling said one or more 
;ments to form at least a portion of said first 
mponent assembly; 


Both scenarios: Using the Window Installer 
OS service with various properties and flags on 
the settings for higher protection. 

Windows Installer has numerous flags that the 
developer can set to indicate how the assembly 
will be installed, in what privilege level, with 
how much user interface, and how much ability 
the user has to watch or change what is 
occurring. These controls have been 
strengthened with each release of Windows 
Installer. Windows Installer 1.1 and later has 
the ability to limit the users capabilities during 
the installation. in a Windows 2000 
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environment and later, using the Group Policy- 
based Change and Configuration Management, 
the administrator has the most control 

Fields that can be set by the developer or 
administrator to control what users can do 
include the following: 

Transformssecure can be set. to a value of 1 . 
to inform the installer that transforms are to be 
cached locally on the user's computer in a 
location the user does not have write access. 
(Transforms create custom installations from a 
basic generic installation, for example to make 
the Finance versions different from the 
Marketing version or English versions different 
from Japanese versions.) 

AllowLockdownBrowse and DisableBrowse 
can prevent users from browsing to the 
sources. 

SourceList can be used to specify the only 
allowable source to be used for the installation 
of a given component. 

Environment can be used to specify whether 
the installation can be done while the user is 
logged on or only when no user is logged on. 

Security Summary Properly conveys whether 
a package can be opened as read-only or with 
no restriction. 

Privileged Property is used by developers of 
installer packages to make the installation 
conditional upon system policy, the user being 
an administrator, or assignment by an 
administrator. 

Restricted Public Properties can be set as 
variables for an installation. "For managed 
installations, the package author may need to 
limit which public properties are passed to the 
server side and can be changed by a user that is 
not a system administrator. Some are 
commonly necessary to maintain a secure 
environment when the installation requires the 
installer use elevated privileges. " 
SecureCustomProperties can be created by the 
author of an installation package to add 
controls beyond the default list. 

MsiSellnternalUI specifies the level of user 
interface from hone to fiilL 

A Sequence Table can be used to specify the 
required order of execution for the installation 
process. There are three modes, one of which is 
the Administrative Installation that is used by 
the network administrator to assign and install 
applications. 

\nstallServicesAction registers a service for 
the svstem and it can onlv he used if the user is 

' I . 
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an administrator or has elevated privileges with 
permission to install services or that the 
application is part of a managed installation. 

DisabhMedia system policy disables media 
sources and disables browsing to media 
sources. It can be used with DisableBrowse to 
secure installations version 1.1 that doesn't 
have some of the other capabilities. 

AlwaysInsiaUElevated can be set per user or 
per machine and is used to install managed 
applications with elevated privileges. 

AllowLockdownBrowse, 
AHowLockdownMedia and 
AUowLockdownPatch set these capabilities so 
they can only be performed by an administrator 
during an elevated installation. . 

[See article "HowTo: Configure Windows 
Installer for Maximum Security (Q24752S). 

Windows XP Professional and .NET have the 
additional capability to set Software Restriction 
Policies and have these used by Windows 
Installer. 

In addition, most of the software distribution 
technologies that use Windows Installer also 
add a layer of their own controls. For example, 
SMS 2.0 enables the administrators to control 
the installation is optional or required and 
whether the user can affect the installation 
contents/features at all. 


e) executing at least some of said executable 
programming; and 


Both scenarios: Part of executable is called 
during installation in order to do self- 
registration or perform custom actions. The 
overall executable is used at runtime. 


f) checking said record for validity prior to 
lerforming said executing step. 


Scenario 1 : Sign the overall package and the 
cabinet files. 

Scenario 2: The cabinet file is signed. 

For IE with the default security level or higher, 
the digital signature is verified by 
Authenticode or a similar utility before the 
component is allowed to be assembled. 
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INTERTRUST TECHNOLOGIES CORP. v. MICROSOFT CORP. 
INTERTRUST INFRINGEMENT CHART 
FOR US. PATENT NO. 5,917,912 


35. 


Products infringing include all products that 
host the Microsoft .NET Common Language 
Runtime or Compact Common Language 
Runtime. 


A process comprising the following steps: 


Computer running the Microsoft CLR/CCLR 
receives, for example, a shared assembly 
header or a complete shared assembly from 
another computer, for example a server. 


(a) at a first processing environment receiving 
a first record from a second processing 
environment remote from said first processing 
environment; ; ; 


(1) said first record being received in a 
secure container: 


The shared assembly is cryptographically 
hashed and signed 


(2) said first record containing 
identification information directly or 
indirectly identifying one or more 
elements of a first component 
assembly: 


The first record is either an assembly manifest, 
or a whole assembly; the elements are other 
assemblies that are referenced as external in 
the first record; the first component assembly 
is a .NET application domain. 


(i) at least one of said elements 
including at least some 
executable programming: 


Assembly contains executable programming. 


(ii) said component assembly 
allowing access to or use of 
specified information: 


The specified information can include any kind 
of data file, stream, log, environment variables, 
etc. - 


(3) said secure container also including 
a first of said elements; 


The shared assembly includes at least some 
executable programming. 


b) accessing said first record 


CLR/CCLR accesses the assembly or 
assembly header. 


c) using said identification information to 
dentify and locate said one or more elements; 


(1) said locating step including locating 
a second of said elements at a third 
processing environment located 
remotely from said first processing 
environment and said second 
processing environment; 


Manifest and type metadata information 
section is used to identify and locate files, code 
elements, resource elements, individual classes 
and methods. 


Met by a multifile assembly, with files 
distributed across a network, or by the second 
element constituting another referenced 
assembly located elsewhere; the CLR/CCLR 
uses probing to locate and access the file. 


d) accessing said located one or more 
dements: 


Step carried out by the CLR/CCLR loader. 


(1) said element accessing step 
including retrieving said second 
element from said third processing 
environment; 


Step carried out by the CLR/CCLR loader. 


e) securely assembling said one or more 
elements to form at least a portion of said first 
component assembly specified by said first 
ecord; and 


CLR/CCLR carries out this slep, including 
checking the integrity of the load module, 
checking the load module's permissions, 
placing the load module contents into an 
application domain, isolating it from malicious 
or badiv behaved code, and from code that 
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does not have the permission to call it. 


(f) executing at least some of said executable 
programming. 


Step carried out by the CLR/CCLR. 


(1) said executing step taking place at 
said . first processing environment. 


CLR/CCLR is operating in the first processing 
environment specified above. 


•jj 
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INTERTRUST TECHNOLOGIES CORP. v. MICROSOFT CORP. 


INTERTRUST INFRINGEMENT CHART 
FOR U.S. PATENT NO, 5,920,861 


34, 


A descriptive data structure embodied on a 
computer-readable medium or other logic 
device including the following elements: 
a representation of the format of data 
contained in a first rights management data 
structure 


Product Infringing: Microsoft Operating 
Systems that support device driver 
signature technology 


The driver package's INF is a data 
structure; The INF contains multiple types 
of sections, structured as hierarchy 
/"branches," that the Windows operating 
system or its Plug and Play and/or Set-up 
installation services "branch" through , 
based on the operating system information 
and device for which a driver is to be 
installed. The installation services use the 
"branching" structure (format) to determine 
what files should be installed. The INF, 
further provides disk location information 
and file directory path information for the 
files identified as necessary as a result of 
the "branching" process. 

The driver package is a "rights 
management" data structure based on the 
fact that it is governed and based on the 
fact that it processes governed information. 

Rights Management as Governed Item 

A driver manufacturer can include rules 
governing the driver's installation and/or 
use in the driver's INF file. For example: 

Security entries specify an access control 
list for the driver. 

Driver developers can specify rules that 
determine behavior of the driver package 
based on the user's operating system 
version, including product type and suite 
Md"tlie"de vice" for which the driver is to be 
installed 

Rules specifying logging 

Local administrators can establish policy as 
to what action or notification should occur 
in the event thai a driver being installed is 
not signed. . . . 
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The operating system installation services 
have a ranking criteria it follows when 
multiple drivers are available for a newly 
detected device. The criterion is used to 
determine the driver best suited for 
ensuring compatibility with the operating 
system and ensuring functionality of the 
device. 

• 

Drivers have been certified to be 
compatible with specified operating system 
versions for their respective device classes. 
The catalog file protects the integrity of the 
driver. 

Microsoft distributes the Driver Protection 
List to prevent known bad deriver from 
being installed. 

Processing Rights Managed Items 

Certain drivers (SAP) have been explicitly 
certified to protect DRM content. 

MSDN - DRM Overview 


A DKM-compliant driver must prevent 
unauthorized copying while digital content 
is being played. In addition, the driver must 
disable all digital outputs that can transmit 
the content over a standard interface (such 
as S/PDIF) through which the decrypted 
content can be captured. 


said representation including: 


element information contained within 
said first rights management data 
structure; and 


The elements of a driver package include: 
A driver that is typically a dynamic-link 
library with the .sys filename extension. 
An INF file containing information that the 
system Setup components use to install 
support for the device. . 
A diriver catalog file containing the digital 
signature. 

One or more optional co-installers which 
are a Win32® DLL that assists in device 
installation NT-based operating systems. 
Other files, such as a device installation 
application, a device icon, and so forth. 

XP DDK - INF Version Section 


The LayoutFile entry specifies one or more 
additional system-supplied INF files that 
contain layout information on the source 
media required for installing the software 
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described in this INF. All system-supplied 
INF files specify this entry. 

The CatalogFile entry specifies a catalog 
(.cat) file to be included on the distribution 
media of a device/driver. • 


organization information regarding 
the organization of said elements 
within said first rights management 
data structure; and 


Within an INF is a hierarchy with the top 
being a list of manufacturers, and subsists * 
of models and at the bottom a list of install 
information by model. 

For Windows XP and later versions of NT- 
based operating systems, entries in the 
Manufacturer section can be decorated to 
specify operating system versions. The 
specified versions indicate OS versions 
with which the specified INF Models 
sections* will be used. If no versions ^re 
specified, Setup uses the specified Models 
section for all versions of all operating 
systems. 

INF's SourceDisksNames and 
SourceDisksFiles sections specify 
organization information. 
XP DDK - Source Media for INFs 


The methods you should use to specify 
source media for device files depend on " 
whether your INFs ship separately from the 
operating system or are included with the 
operating system. 
INFs for drivers that are delivered 
separately from the operating system 
specify where the files are located using 
SourceDisksNames and SourceDisksFiles 
sections. 

If the files to support the device are 
included with the operating system, the 
INF must specify a LayoutFile entry in the 
Version section of the file. Such an entry 
specifies where the files reside on the 
operating system media. An INF that 
specifies^ LayoutFile entry must not 
include SourceDisksNames and 
SourceDisksFiles sections. 
XP DDK - INF SourceDisksNames 


Section 


A SourceDisksNames section identifies 
the distribution disks or CD-ROM discs 
that contain the source files to be 
transferred lo the target machine during 
installation. Relevant values of an entry in 
the INF include: 
diskid Specifies a source disk. 
disk-description - Describes the contents 
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and/or purpose of the disk identified by 
diskid. 

iag-or-cab-file ~ This optional value 
specifies the name of a tag file or cabinet file 
supplied on the distribution disk, either in. 
the installation root or in the subdirectory 
specified by path, if any. 
path— This optional value specifies the 
path to the directory on the distribution 
disk containing source files. The path is 
relative to the installation root and is 
expressed as\dirnamel\dirname2„. and so 
forth. : 

flags For Windows XP and later, setting 
this to 0x10 forces Setup to use cab-or-tag- 
file as a cabinet file name, and to use tag- 
file as a tag file name. Otherwise, flags is 
for interna! use only. 
tag-file For Windows XP and later, if 
flags is set to 0x10, this optional value 
specifies the name of a tag file supplied on 
the distribution medium, either in the 
installation root or in the subdirectory 
specified by path. The value should specify 
the file name and extension without path 
information. 

XP DDK INF SourceDisksFiles Section 


A SourceDisksFiles section names the 
source files used during installation, 
identifies the source disks (or CD-ROM 
discs) that contain those files, and provides 
the path to the subdirectories, if any, on the 
distribution disks containing individual 
files. Relevant values in an entry in the 
INF would include: 

filename — Specifies the name of the file on 
the source disk. 

diskid — Specifies the integer identifying 
the source disk that contains the file. This 
value and the initial path to the 
subdirectory), if any, containing the 
named file must be defined in a 
SourccDisksNames section of the same 
INF. 

subdir — This optional value specifies the 
subdirectory (relative to the 
SourccDisksNames path specification, if 
any) on the source disk where the named 
file resides. 


information relating to metadata, said 
metadata including: 


metadata rules used at least in part to 
govern at least one aspect of use and/or 
display of content stored within a rights 
management data structure, . 


The driver manufacture can specify rules in 
the INF that govern the installation and/or 
use of the driver. For example, security 
en tries. specify an access control list for the 
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driver. Driver developers can specify rules 
in an INF file that determines behavior of 
the driver package based on the user's 
operating system version, including 
product type and suite. Also, rules related 
to logging can be specified as mentioned in 
next claim element. 

For Example - Access Control List 


Rules 


XP DDK - Tightening File-Open 


Security in a Device INF File 


For Microsoft Windows 2000 and later, 
Microsoft tightened file-open security in 
the class installer INFs for certain device 
classes, including CDROM, DiskDrive, 
FDC, FloppyDisk, HDC, and 
SCSIAdapter. 

If you are unsure whether the class installer 
for your device has tightened security on 
file opens, you should tighten security by 
using the device's INF file to assign a value 
to the DeviceCharacteristics value name 
in the registry. Do this within an add- 
registry-section, which is specified using 
the INF AddReg directive. 
XP-DDK - INF AddReg Directive 

An INF can also contain one or more, 
optional add-registry-section.stcu rity 
sections, each specifying a security 
descriptor that will be applied to all registry 
values described within a named odd- 
registry-section. 

A Security entry specifies a security 
descriptor for the device. The security- 
descriptor-string is a string with tokens to 
indicate the DACL (D:) security 
component A class-installer INF can 
specify a security descriptor for a device 
class. A device INF can specify a security 
descriptor for an individual device, 
overriding the security for the class. If the 
class and/or device INF specifies a 
security-descriptor-string, the PnP 
Manager propagates the descriptor to all 
the device objects for a device, including 
the FDO, filter DOs, and the PDO. 

For Example - Operating System 
Versioning 

Operating-Svstem Versioning for Drivers 
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said metadata rules including at least 
one rule specifying that information 
relating to at least one use or display of 
said content be recorded and/or 
reported. 


under Windows XP 

Setup selects the [Models] section to use 
based on the following rules: 

If the INF contains [Models] sections for 
several major or minor operating system 
version numbers, Setup uses the section 
with the highest version numbers that are" 
not higher than the operating system 
version on which the installation is taking 
place. 

If the INF [Models] sections that match the 
operating system version also include 
product type decorations, product suite 
decorations, or both, then Setup selects the 
section that most closely matches the 

running operating system. : 

The AddService directive can set up event- 
logging services for drivers. 
INF AddService Directive 
An AddService directive is used to control 
how (and when) the services of particular 
Windows 2000 or later device's drivers are* 
loaded, any dependencies on other 
underlying legacy drivers or services, and 
so forth. Optionally, this directive sets up 
event-logging services by the 
devices/dnvers as well. 
Relevant sections of the directive's entry 
include: 

event-log-install-section -Optionally 
references an INF-writer-defined section in 
which event-logging services for this 
device (or devices) are set up. 
EyentLogType -- Optionally specifies one 
of System, Security, or Application. If 
omitted, this defaults to System, which is 
almost always the appropriate value for the 
installation of device drivers. For example, 
an INF would specify Security only if the 
to-be-installed driver provides its own 
security support. 

EventName — Optionally specifies a name 
to use for the event log. If omitted, this 
defaults to the given ServiceName. 


15. A descriptive data structure as in claim 
i4, in which: 


aid first rights management data structure 
:omprises a first secure container. 


The driver package is secured through a 
catalog file that is signed by Microsoft's. 
Windows Hardware Quality Lab and 
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contains the hash of each file of the driver's 
package. The INF identifies the catalog 
file used to sign the driver package. 


36. A descriptive data structure as in claim 
35, in which: 


said first secure container comprises: • 

The first secure container is the driver 
package secured by a catalog file. 

said content; and 

The content is the driver afid related files 
within the signed driver package. 

rules at least in part governing at least 
. one use of said content. 

The rules are within the INF, which is part 
of the signed driver package. 


37. A descriptive data structure as in claim 
36, wherein the descriptive data structure is 
stored in said first secure container. 

The INF is stored within the signed driver 
package. 


A dp^rrintivp data ctm^tnr-p 1*1 claim 
34. further including: 


a representation of the format of data 
contained in a second rights management 
data structure, 

The manufacture and models sections in 
the INF Version section are provided for 
the possibility of a single INF representing 
the format for multiple drivers. 

Operating system version "decorating" 
relating the architecture, major and minor 
operating systems versions, product and 
suit information all relate to the target 
environment and is used to identify the 
files necessary for the target environment. 

An INF file, such as in the case of 
operating system targeting, can be used for 
more than one driver package since it can 
contain more than one catalog file. 

Further an INF can address the drives 
necessary for a multi-functional device. 

said second rights management data 
structure differing in at least one respect 
from said first rights management data 
structure. 

The files of the second data structure would 
vary from the files on the first data 
structure. 


45. A descriptive data structure as in claim 
44. in which: 


said information regarding elements 
contained within said first rights 
management data structure includes 
information relating to the location of at 
least one such element. 

INF specify where the driver files are 
located using the SourceDiskNames and 
SourceDiskFiles sections. 


46. A descriptive data structure as in claim 
44. further including: 


a first target data block including 
information relating to a first target 

Operating system version ''decorating" 
relatingithe architecture, major and minor 

■1! 
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environment in which the descriptive data 
structure may be used. 


operating systems versions, product and 
suit information all relate to the first target 
environment. : 


47. A descriptive data structure as in claim 
46. further including: 


a second target data block including 
information relating to a second' target . 
environment in which the descriptive data 
structure mav be used. 

Operating system version decorating will 
cover multiple operating systems. 

said second target environment differing in 
at least one respect from said first target 
environment. 

This is the reason for version decorating. 


48. A descriptive data structure as in claim 
46. further including: 


a source message field containing 
information at least in part identifying the 
source for the descriptive data structure. 

The provider entry in the version section of 
the INF identifies the provider of the INF 
file. Also, the INF contains a manufacture 
section. 
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INTER TRUST TECHNOLOGIES CORP. v. MICROSOFT CORP. 
INTERTRUST INFRINGEMENT CHART 
FOR U.S. PATENT NO. 5,920,861 


58. 


Product Infringing: Microsoft Reader SDK 
and Microsoft Digital Asset Server. ; 


^ method of creating a first secure 
;ontainer, said method including the 
bllowing steps 


Method is carried out by Microsoft's 
Digital Asset Server and Microsoft's 
Xitgen tools 


a) accessing a descriptive data structure, 
said descriptive data structure 
including or addressing 


(1) organization information at least 
in part describing a required or 
desired organization of a content 
section of said first secure 
container, and 


.opf file describing the file structure of a 
protected e-book including metadata, 
manifest, and "spine 1 " information 


Organization information regarding 
organization of the ebook and the 
inscription as specified in the manifest and 
spine information in the .opf file 


(2) metadata information at least in 
part specifying at least one step 
required or desired in creation of 
said first secure container; 


Metadata constitutes rules specifying the 
degree of security to use and/or XrML 
rules 


:>) using said descriptive data structure to 
organize said first secure txmtainer 
contents 


e-book packaging carried out by Microsoft 
Litgen tool 


:) using said metadata information to at 
least in part determine specific 
information required to be included in 
said first secure container contents; 

and "•. 


Step performed by Digital Asset Server; 
example of specific information is 
owner/purchaser information required in 
the inscription process 


1) generating or identifying at least one 
rule designed to control at least one 
aspect of access to or use of at least a 
portion of said first secure container 
contents. 


Analyzing the metadata and finally 
packaging the e-book using a particular 
security level specified through the 
metadata 


1. A method as in claim 58. in which: 


i) said specific information required to 
be included includes information at 
least in part identifying at least one 
owner or creator of at least a portion of 
said first secure container contents. 


Owner purchaser information required in 
the inscription process; XrML rule 
requiring display of copyright notice 
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JNTERTRUST TECHNOLOGIES CORP. v. MICROSOFT CORP. 
INTERTRUST INFRINGEMENT CHART 
FOR U.S. PATENT NO. 5,920,861 


58. 


Product Infringing: All products that host 
the Microsoft Common Language Runtime 
or Compact Common Language Runtime. 


A method of creating a first secure 
container, said method including the 
bllowing steps; 


Method is practiced by a user using the 
Common Language Runtime (CLR) or 
Compact Common Language Runtime 
(CCLR) to create a dynamic shared 
assembly or .NET Framework SDK to 
create a shared assembly 


a) accessing a descriptive data structure, 
said descriptive data structure 
including or addressing 


.NET framework Assembly class and/or 
AssemblyBuiider class and/or 
Assemblylnfo file 


(1) organization information at least 
in part describing a required or 
desired organization of a content 
section of said first secure 
container, and . i 


This information is specified in the classes 
named above and in the Assemblylnfo file. 


(2) metadata information at least in 
part specifying at least one step 
required or desired in creation of 
said first secure container; 


This information is addressed in the classes 
and the Assemblylnfo file, e.g., for a shared 
assembly metadata will be specified that 
the assembly is to be signed using specified 
key : 


b) using said descriptive data structure to 
organize said first secure container 
contents; 


This step is carried out by applications and 
tools using the classes and assembly info 
file, including CLR (or CCLR) and .NET 
Framework SDK 


:) using said metadata information to at 
least in part determine specific 
information required to be included in 
said first secure container contents; 
and 


This step is carried but by applications and 
tools using the assembly info file and 
classes that specify the metadata required 
in the target assembly 


i) generating or identifying at least one 
rule designed to control at least one 
aspect of access to or use of at least a 
portion of said first secure container 
contents. 


User may specify rules, as specified in the 
.NET Framework SDK, to be placed in the 
assembly manifest including such rules 
requiring that all code be managed (CLR or 
CCLR compliant), "Code Access Security" 
permissions be supplied for use of code 
su pplied in the assembly, etc 


4. A method as in claim 58. in which; 


i) said creation of said first secure 
container occurs at a first data 
processing arrangement located at a 
first site; 


Can be a server, PC or workstation running 
CLR (or CCLR) to create a dynamic shared 
assembly or .NET Framework SDK to 
create a shared assembly) 


)) said first data processing arrangement 
including a communications port; and 


Included in virtually any compute! 


f) said method further includes: 


(1) prior to said step of accessing said 
descriptive data structure, said 


Download of the assemblyinfo file and/or a 
file containing a class calling the ^_ 
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first data processing arrangement 
receiving said descriptive data 
structure from a second data 
processing arrangement located at 
a second site. 


DefineDynamicAssembly methods or 
download of SDK containing 
assemblybuilder class from a second site 


'd_) said receipt occurring through said first 
data processing afr'aDgenient 
communications port. 


Communications port is normally used for 
downloading 


57. A method as in claim 64, further 
comprising: 


it said first processing site, receiving said 
metadata through said communications 
port 


Download of the Assemblylnfo file and/or 
a file containing a class calling the 
DefineDynamicAssembly methods or 
download of SDK containing 
assembivbuilder class from a second site 


i8. A method as in claim 67 ? in which. 


a) said metadata is received separately 
from said descriptive data structure. 


Method practiced when metadata names are 
addressed by the assembly class and a 
template for the Assemblylnfo file, and 
values corresponding to those names are 
received through a user interface such as 
provided by Microsoft Visual Studio or are 
provided from a separate file 


1. A method as in claim 58. in which: 


a) said specific information required to 
be included includes information at 
least in part identifying at least one 
owner or creator of at least a portion of 
said first secure container contents. 


The Assembly class definition includes 
attributes for company name and trademark 
information, and these may be required 
attributes specified in the Assemblylnfo file 


2. A method as in claim 58, in which: 


i) said specific information required to 
be included includes a copyright 
notice. 


The Assembly class definition includes an 
attribute for copyright field that may be 
required by the Assemblylnfo file 
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58. 

Product Infringing: Microsoft .NET 
rramewonc, visual otudio .iNxil , ana loois 
that include the Assembly Generator tool 
AL.exe. 

A method of creating, a first secure 
container, said method including the 
following steps; 

The Assembly Generation tool generates : 
a portable execution file with an assembly 
manifest from one or more files that are 
either Microsoft intermediate language 
(MSIL) modules or resource files, When 
using the tool's signing option, the 
assembly becomes a secure container. 

(a) accessing a descriptive data structure, 

<v?nH Hp^rnntivp ffatfl structure 

including or addressing 

The descriptive data structure is the text 
file used as input by the Assembly 
Generation tool. 

(1) organization information at least 
in part describing a required or 
desired organization of a content 
section of said first secure 
container, and 

The DDS specifies the link and or embed 
directives to indicate which source files 
should be included in the assembly, how 
the included resource will be tagged, and if 
the resource will be private. Private 
resources are not visible to other 
assemblies. 

These tags are used to organize the 
assembly into named sections. 
Private attributes are used to organize the 
assembly into both public and private 
sections. (Tublic sections are the default.) 

(2) metadata information at least in 
part specifying at least one step 
required or desired in creation of 
said first secure container; 

The text file can contain "options" relating 
to how the assembly should be built and 
additional information that should be 
included. 

Main - Specifies the method to use as 
an entry point when converting a 
module to an executable file. 
Algid - Specifies an algorithm to hash 
all files. 

Comp - Specifies string for the 

Company field. 

Conf - Specifies string for 

Configuration field 

Copy - Specifies string for Copyright 

field. 

Culture - Specifies the culture string 10 
associate with the assembly. . 
Delay - Variation of this option . 
jjsDecifies whether the assembly will be 


II 
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fully or partially signed and whether the 
public key is placed in the assembly. 
Description - Specifies the description . 
field. 

Evidence - Embeds file in the assembly 
with the resource name 
Security.Evidence. 

Fileversioh - Specifies the file version 
of the assembly. 

Flags - Specifies flags for such things 
as the assembly is side-by-side 
compatible, assembly cannot execute 
with other versions if eitherthey are 
executing in the same application 
domain, process or computer. 
Key/- Specifies a file that contains a 
key or key pair to sign an assembly. 
Ksyn - Specifies the container that holds 
a key pair. 

Product - Specifies string for Product 
field. 

Productv - Specifies string for Product 
Version. 

Template - Specifies the assembly fro 
which to inherit all assembly metadata. 
Title - Specifies string for Title field. 
Trade - Specifics string for Trademark 
field. 

V- Specifies version information 


(b) using said descriptive data structure to 
organize said first secure container 
contents 


The following directives are used to specify 
which files are to be compiled into the 
assembly, how they will be tagged, and 
whether or not they will be visible to other 
assemblies, AKA private: 

Embedfname, private J - copies the 
content of the file into the assembly and 
applies an optional naime tag, and 
optional private attribute. 
ZmA/hame, private] - file becomes part 
of the assembly via a link and applies an 
optional name tag, and optional private 
attribute. 


(c) using said metadata information to at 
least in part determine specific 
information required to be included in 
said first secure container contents; 
and 


The following are some of the "options" 
address what information should be 
included in the secure container 

Main - Specifies the method to use as 
an entry point when converting a 
module to an executable file. 
Comp - Specifies string for the 
Company field. 
Conf- Specifies string for 
Configuration field 
Copy- Specifies string for Copyright 


ii 
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field. 

Culture - Specifies the culture string to 
associate with the assembly. 
Description - Specifies the description 
field. 

Evidence - Embeds file in the assembly 
with the resource name •; 
Security .Evidence. . 
Fileversion - Specifies the file version 
of the assembly. 

Flags - Specifies flags for such things 
as the assembly is side-by-side 
compatible, assembly cannot execute 
with other versions if either they are , 
executing in the same application 
domain, process or computer. 
Keyf - Specifies a file that contains a 
key or key pair to sign an assembly. 
. . Keyn - Specifies the contained that holds 
a key pair. 

Product - Specifies string for Product 
field. 

Products - Specifies string for Product 
Version. 

Template - Specifies the assembly fro 
which to inherit all assembly metadata. 
Title - Specifies string for Title field. 
Trade - Specifics string for Trademark 
field. 

V- Specifies version information. 

(d) generating or identifying at least one 
ml** dp^icmed to control at least one 
aspect of access to or use of at least a 
portion of said first secure container 
contents. 

User may specify rules, as specified in the 
.NET Framework SDK, to be placed in the 
assembly manifest including such rules 
requiring that all code be managed (CLR 
compliant), "Code Access Security" 
permissions be supplied for use of code 
supplied in the assembly, etc. 

71. A method as in claim 58, in which: 


(a) said specific information required to. 
be included includes information at 
least in part identifying at least one 
owner or creator of at least a portion of 
said first secure container contents. 

The following "options" specifies owner 
and creator information: 

Comp - Specifies string for the 
Company field. 

Copy- Specifies string for Copyright 
field. 

Trade - Specifics string for Trademark 
field. 

72. A method as in claim 58, in which: 


(a) said specific information required to 
be included includes a copyright 
notice. 

The copy "option" specifies the string for 
the for the Copyright field. 


ji 

Exhibit Si 

• r 3] 


1 

2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 


INTERTRVST TECHNOLOGIES CORP. v. MICROSOFT CORP. 
INTERTRUST INFRINGEMENT CHART 
FOR U.S. PATENT NO. 5,982,891 


Products infringing: All products that include 
the Common Language Runtime or Compact 
Common Language Runtime or Common 
Language Infrastructure. 


k method for using at least one resource 
irocessed in a secure operating environment at 
first appliance, said method comprising: 


Resource may constitute a Microsoft Windows 
process or hardware element; secure operating 
environment is Microsoft Common Language 
Runtime ("CLR") environment, Common 
Language Infrastructure ("CLI") or Compact 
CLR ("CCLR"); first appliance is computer 
running CLR, CLI or Compact CLR. Two 
infringing scenarios are set forth herein: (1) 
For CLR, an administrator, using the .NET 
framework, caspol.exe tool remotely configures 
security policy in a .NET configuration file for 
a machine, enterprise, user, or application and 
that security policy interacts with rules or 
evidence declared in a shared assembly 
provided by another entity ("1 st scenario"); and 
(2) for CLR, CLI and CCLR two assemblies 
are delivered to an appliance; the first 
assembly has a rule that demands permissions 
from a caller in the second assembly, and the 
second assembly includes a control that asserts 
such permissions or provides evidence that 
convinces the runtime that it has such 
permissions. ("2 nd scenario"). In each scenario 
Microsoft .NET "Code Access Security" 
framework or "Role Based Security" 
framework is used. 


) securely receiving a first entity's control at 
id first appliance, said first entity being 
cated remotely from said operating 
ivironment and said first appliance; 


l sl scenario: first entity is the administrator, 
and the policy that constitutes this entity's 
control is securely received at the first 
appliance through a session established 
between the administrator's computer and the 
first appliance, requiring security credentials 
such as the administrator's login and password 
or other secure session means. 
2 nd scenario: first entity is creator or distributor 
of the first assembly, assembly manifest 
includes a control demanding or refusing or 
otherwise asserting a security action on 
permissions from a caller; first assembly is 
integrity-checked. 


) securely receiving a second entity's control 
said first appliance, said second entity being 
cated remotely from said operating, 
ivironment and said first appliance, said 
cond entity being different from said first 


Second entity's control is contained in shared 
assembly manifest (and therefore integrity 
protected) that provides evidence for obtaining 
permissions, or asserts permissions; assembly 
creator/distributor is located remotely and is 
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entity; and 


not the administrator (1 scenario) or 
creator/distributor of the first container (2 nd 
scenario): 


(c) securely processing a data item at said first 
appliance, using at least one resource, 
including securely applying, at said first 
appliance through use of said at l east one 
resource said first entity's control and said 
second entity's control to govern use of said 
data item. 


Secure processing is carried out by CLR, CLI 
or CCLR, Data item constitutes an executable 
code element, an interface controlled by such 
an executable, a data collection or stream (such 
as media file or stream or text file) or an. . 
environment variable* CLR, CLI or CCLR 
securely processes the rules, which will in both 
scenarios govern access to methods and data 
from the first assembly. The resource named in 
the claim is, e.g., a Windows process that is 
established by the runtime or hardware ejement 
on the computer. 


51i A method as in claim 1 wherein at least 
said secure processing step is performed at an 
jnd user electronic appliance. 


Consumer computer or appliance running 
Microsoft CLR, CLI or CCLR). 


58. A method as in claim 1 wherein the step of 
securely receiving a first entity's control 
comprises securely receiving said first entity's 
;ontroI from a remote location over a 
elecommunications link, and the step of 
securely receiving said second entity's control 
comprises securely receiving said second 
;ntity's control from the same or different 
emote location over the same or different 
elecommunications link. 


1 51 scenario 1 : link is LAN or WAN; 2 na 
scenario: link is any telecommunications link, 
including the internet. 


Secure processing environment is CLR, CLI or 
CCLR running on user's computer or 
appliance. 


>5. A method as in claim 1 wherein the 
>rocessing step includes processing said first 
md second controls within the same secure 
jrocessing environment. 


1. A method as in claim 1 further including 
he step of securely combining said first 
ntity's control and said second entity's control 
o provide a combined control arrangement. 


In scenario 2, arrangement consists of the stack 
frame, and the corresponding array of 
permission grants for assemblies on the stack, 
and the permission demanded by the first 
assembly. Secure combining performed by the 
CLR. CLI or CCLR. 


6. A method as in claim 1 wherein said two 
ecurely receiving steps are independently 
lerformed at different times. 


Steps are performed at different times in both 
scenarios. 


4. A method as in claim 1 wherein at least one 
if the first entity's control and the second 
ntity's control comprises at least one 
xecutable component and at least one data 
omponent. 


In both scenarios the second entity supplies an 
assembly with a demand procedure executed 
by the CLR, CLI or CCLR. The data 
component is a specific attribute value 
referenced by the assembly. 


9. A method as in claim 1 wherein said first 
ppliance includes a protected processing 
nvironment ? and wherein: 


Microsoft Common Language Runtime (CLR), 
Common Language Infrastructure (CLI), or 
Compact Common Language Runtime (CCLR) 
environment. 


a) said method further comprises a step of 
eceiving. at said first appliance, said data item 


Typically occurs in both scenarios. 
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separately and at a different time from said . 
receiving said first entity's control : and 
(b) said securely processing step is performed 
at least in part in said protected processing 
environment 


Protected processing environment is the CLR, 
CLIorCCLR. 
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12. 


\ method of securely controlling use by a third 
:>arty of at least one protected operation with 
espect to a data item comprising: 


Infringing products include Office 2003 and 
included applications, and Server 2003, 
including Microsoft ho$ted RMS Service using 
Passport 


A user (third party) accesses an IRM-protected 
data item governed by IRM controls under two 
or more RMS servers. For example, the data 
item may be a IRM-protected document 

The IRM controls may be associated with the 
data item directly or via a IRM-protected 
container holding the IRM-protected data item, 
such as an IRM-protected email .with the IRM 1 
protected document attached. 


a) supplying at least a first control from a first 
>arty to said third party; 


The user acquires a first use license from a first 
RMS server (first party) enabling access to, the 
IRM-protected data item under the IRM rules 
associated with the first RMS server. For 
example: (1) the first use license from the first 
RMS server permits the user to access a IRM- 
protected document contained within or 
attached to an IRM-protected email; or (2) the 
first use license from the first RMS server 
applies a first set of IRM rules to an IRM- 
protected document. 


b) supplying, to said third party, at least a 
econd control from a second party different 
irom said first party; 


The user acquires a second use license from a 
second RMS server (second party) enabling 
access to the IRM-protected data item under 
the IRM rules associated with the second RMS 
server. For example: (1) in addition to the 
user being given access to an IRM-protected 
email based on a first use license, a second 
RMS server provides a second use license 
enabling access to the IRM-protected 
document attached thereto; or (2) the second 
use license from the second RMS server 
applies a second set of IRM rules to the IRM- 
protected document. 


c) securely combining at said third party's 
Dcation, said first and second controls to form 
control arrangement; 


The first and second use licenses are combined 
to form a control arrangement that governs 
access to the IRM-protected data item. 


d) securely requiring use of said control 
rrangement in order to perform at least one 
rotected operation using said data item: and 


The combined first and second use licenses 
govern access to the IRM-protected data item. 


s) securely performing said at least one 
rotected operation on behalf of said third 
arty with respect to said data item by at least 
i part employing said control arrangement 


The user performs a protected operation (e.g., 
read, print, edit) on the IRM-protected data 
item. The combined first and second use 
licenses are employed to permit the protected 
operation. • " * 
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23. A method as in claim 22 wherein said data 
item is protected. 


The data item is encrypted and protected by 
IRM. 


39. A method as in claim 22 further including 
securely and persistently associating at least 
Dne of: (a) said first control, (b) said second 
:ontrol } and (c) said control arrangement, with 
said data item. ^ 


The first and/or second use license are securely 
and persistently associated with the IRM- 
protected data item. 


Steps performed at a user's computer or 
appliance. 


53. A method as in claim 22 wherein at least 
:wo of the recited steps are performed at an end 
jser electronic appliance. 


50. A method as in claim 22 wherein step (a) 
emprises supplying said first control from at 
east one remote location over a 
elecommunications link, and step (b) 
:omprises supplying said second control from 
he same or different remote location over the 
;ame or different telecommunications link 


The first and second use licenses are received 
over a telecommunications link Such as a 
networking or modem/serial interface. 


>7. A method as in claim 22 wherein at least 
;tep (c) is performed within the same secure 
>rocessing environment at said third party's 
ocation. 


Steps are performed at user's computer or 
appliance. 


H. A method as in claim 22 wherein: 


a) said method further comprises supplying 
aid data item to said third party separately and 
tt a different time from supplying of said first 
ontrol to said third party; and 


The first use license (first control) is received 
at the time that the user accesses the data item, 
which occurs separately and at a different time 
from receipt of the IRM-protected data item 
itself. 


b) said securely performing step comprises 
performing said protected operation at least in 
►art in a protected processing environment. 


The protected operations require decryption of 
the protected content, which is done inside the 
RM lockbox. The RM lockbox is protected by 
mechanisms such as obfuscation, anti- 
debugging, and tamper resistance. 
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16. 


Products infringing: Visual Studio.NET, • 
.NET Framework SDK, and all products 
that include the Common Language 
Runtime or Compact Common Language 
Runtime or Common Language 
Infrastructure. : 


A secure method for combining data 
terns into a composite data item 
comprising: 


a) securely providing, from a first location 
o a second location, a first data item 
laving at least a first control associated 
herewith; 


A first signed and licensed .NET 
component, .NET assembly, managed 
control and/or Web control (component) i& 
the first data item. The first .NET 
component developer (first location) 
provides the application assembly 
developer (second location) the first 
component The first control is the set of 
declarative statements comprising the 
LicenseProviderAttribute (alternately 
referred to as license controls'). 


b) securely providing, from a third 
Dcation to said second location, a second 
ata item having at least a second control 
ssociated therewith; 


A second signed and licensed component is 
the second data item. The second 
component developer (third location) 
provides the application assembly 
developer (second location) the second 
component. The second control is the set 
of declarative statements comprising the 
LicenseProviderAttribute. ' 


:) forming, at said second location, a 
omposite of said first and second data 
ems: 


The application assembly developer will 
include at least the two components into its 
assembly. 


i) securely combining, at said second 
>cation, said first and second controls to 
)rm a control arrangement; and 


At the second location, the application 
assembly developer uses the .NET runtime 
that includes the LicenseManager. 

Whenever a component is instantiated 
(here, an instance of the first licensed 
component), the license manager accesses 
the proper validation mechanism for the 
component. The license controls (first 
control) for the runtime license (derived 
from the design-time license) are bound 
into the header of the .NET application 
assembly, along with the second control for 
the second component. 

Visual Studio.NET securely handles the 
creation of runtime license controls. 
Runtime licenses are embedded into (and 
bound to) the executing application 
assembly. The license control attribute 


ii 


Exhibit B 


8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 


included in the first component is 
customized in the second location to 
express and require the runtime license. In 
a more advanced scenario, the License 
Complier tool can be used to create a 
".licenses file" containing licenses for 
multiple components, including runtime 
licenses for components and classes created 
by the license provider. This .licenses file 
is embedded into the assembly. 

The third control set comprises the runtime 
license controls for the first and second 
components (that had been bound to the 
assembly), the declarative controls 
provided by the application assembly 
developer, and any runtime licenses for 
other components included by the 
developer in application assembly. The 
controls are typically integrated into the 
header of the .NET application assembly 
calling the first licensed component. 


(e) performing at least one operation on 
said composite of said first and second data 
items based at least in part on said control 
arrangement. 


The proper execution of the application 
will require that the assembly have run 
time licenses for the two components. 


27. A method as in claim 26 wherein said 
combining step, includes preserving each of 
said first and second controls in said 
composite set , 


The set of declarative statements 
comprising the LicenseProviderAttribute of 
both the first and second components are 
included in the application assembly. 


28. A method as in claim 26 wherein said 
performing step comprises governing the 
operation on said composite of said first 
and second data items in accordance with 
said first control and said second control. 


The application will require the first and 
second controls to operate properly when it 
calls the first and second data items, 
respectively. 


29. A method as in claim 26 wherein said 
providing step includes ensuring the 
integrity of said association between said 
first controls and said first data item is 
maintained during at least one of 
transmission, storage and processing of 
said first data item. 


Signing the component that has embedded 
within it the license control ensures the 
integrity of the association of the control 
and data item. 


31. A method as in claim 26 wherein said 
providing step comprises codelivering said 
first data item and said first control. 


The component includes the license control 
and therefore they are codelivered. 


40. A method as in claim 26 further 
including the step of securely ensuring that 
at least one of (a) said first control, (b) said 
second control, and (c) said control 
arrangement, is persistently associated with 


Each component includes the license 
control. Signing the component that has 
embedded within it the license control 
ensures the persistence of the association of 
the control and data item. . . 
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at least one of said first and second data 
items. 


54. A method as in claim 26 wherein at 
least one of steps (c), (d) and (e) is 
performed at an end user electronic 
appliance. __i , 


At least step (e) is typically performed at an 
end-user electronic appliance. 


SI. A method as in claim 26 wherein step 
[a) comprises providing said first data item 
from at least one remote location over a 
elecommunications link, and step (b) 
comprises providing said second data item 
rom the same or different remote location 
>ver the same or different 
elecommunications link. 


Microsoft maintains Web sites where a 
developer can get components over the 
Web. These sites include references 
whereby a developer may obtain 
components, through their Web connection. 
One such site is Internet Explorer Web 
Control Gallery at 

ie.components.microsoft.com/webcontrols 


>8. A method as in claim 26 wherein step 
d) is performed within the same secure 
>rocessing environment at said second 
ocation. 


Typically, step (d) will be performed 
within the same secure processing • 
environment. 


'9. A method as in claim 26 wherein steps 
a) and (b) are performed at different times. 


The application assembly developer will 
typically acquire components at different 
times. 


!6. A method as in claim 26 wherein at 
sast one of the first and second controls 
omprises at least one executable 
omponent and at least one data 
proponent. 


The component must include an executable 
and can include a data items as a EULA* 
readme file or help file. 
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Infringing products include: Windows 
Media Player, Individualized DRM Clients 
and the Secure Audio Path (SAP) 
technology. : ^_ 


A method for using at least one resource 
processed by a secure operating . 
environment said method comprising: 


securely receiving a first load module 
provided by a first entity external to said 
operating environment 


The Individualized DRM Client (first load 
module) is a signed security upgrade DLL. 
It is also bound to the hardware ID of the 
machine on which it runs. It is therefore 
securely delivered and integrity protected. 


A SAP certified driver is also signed and 
carries with it a certificate that indicates its 
compliance with SAP criteria. If it is 
delivered to a PC it is secure in the sense 
that it is integrity protected. This driver 
would not come from the same entity as the 
Individualization DLL. 


securely receiving a second load module 
provided by a second entity external to said 
operating environment, said second entity 
being different from said first entity; and 


securely processing, using at least one 
resource, a data item associated with said 
first and second load modules, including 
securely applying said first and second load 
modules to manage use of said data item. 


If a WM audio file targeted to the 
Individualized DRM client carries with it a 
requirement that SAP be supported to 
render the WMF contents, the content is 
processed for playing through a soundcard 
using the WMP and by applying the DRM 
client - which decrypts the content and 
negotiates with the DRM kernel processing 
of the content through a Secure Audio Path 
that includes the SAP-certified audio 
driver. 


56. A method as in claim 35 wherein at 
least two of the recited steps are performed 
at an end user electronic appliance. 


All steps occur at the user's PC that 
supports the WMP and DRM client and 
SAP. 


S3. A method as in claim 35 wherein said 
first load module receiving step comprises 
securely receiving said first load module 
from at least one remote location over at 
east one telecommunications link, and said 
second load module receiving step 
:omprise§ securely receiving said second 
oad module from the same or different 
emote location over the same or different 
elecommunications link. 


The Driver and DRM client are received 
from distinct locations and may be 
delivered securely over the Internet. They 
are delivered securely in that each is 
integrity protected. 


70. A method as in claim 35 wherein said, 
securely processing step comprises 
securely executing said first and second 


Both load modules are executed on the PC 
within the WMP/DRM Client/SAP 
environment. -. » . . 


i! 
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load modules within the same secure 
processing environment. 


74. A method as in claim 35 further 
including securely, combining said first and 
second 'load modules to provide a 
;ombined executable. 


Since both the DRM client and the driver . 
are' DLLs in the same audio rendering 
chain* they exist as an execution 
environment 


The driver and Individualization DLL need 
not be received at the same time. 


Jl. A method as in claim 35 wherein said 
•ecurely receiving steps are performed 
ndependentlv at different times. 


>4. A method as in claim 35 wherein said 
;ecure operating environment includes a 
)rotected processing environment, and 
vherein: 

aid method further comprises receiving a 
lata item within said secure operating 
mvironment; 

aid first load module receiving step is 
>erformed separately and at a time different 
rom receiving said data item; and 

aid securely processing step is performed 
t least in part in said protected processing 
nvironment. ; 


The Windows Media Player together with • 
the Individualized DRM Client and Secure 
Audio Path comprise a protected 
environment for processing protected 
media. The protected Windows Media . 
Files are received after the load modules 
have been received and installed (licenses 
cannot be acquired until load modules are 
in place). The processing of the Windows 
Media File occurs in the protected 
environment. 


Examples of SAP-certified drivers include - as indicated at 
ttp'7/www.microsoftxom/Windows/windowsmedia/WM7/DRM^ 


All VIA controllers with AC-97 codecs 

All ALI controllers with AC-97 codec 

Intel ICH controllers with AC-97 codecs 

Creative Labs SoundBlaster 16/AWE32/AWE64/Vibra 

Yamaha OPL3 

Yamaha DS-1 

Cirrus Logic (Crystal) CS4280 
Cirrus Logic (Crystal) CS46 1 4 / CS4624 
ESS Maestro 2E 
USB Audio 

Cirrus Logic (Crystal) CS4281 
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• All SiS controllers with AC-97 codecs 

■ EnsoniqES1370 

■ NeoMagic NM6 

- EnsoniqES1371/73andCT5880 

• SoundBlaster Live! 

• Aureal 8810 
» Aureal 8820 

• Aureal 8830 

• Conexant Riptide 

• ESS Maestro 

■ ESS ISA parts 

• NeoMagic NM5 
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INTERTRUST TECHNOLOGIES CORP. v. MICROSOFT CORP. 


INTERTRUST INFRINGEMENT CHART 
FOR U.S. PATENT NO. 5,982,891 


36. 


Product Infringing: Any product Using 
Commoa Language Runtime (CLR), Common 
Language Infrastructure (CLI), or Compact 
Common Language Runtime (CCLR) 


A secure operating environment system for 
managing at least one resource comprising: 


Microsoft CLR, CLI or CCLR (operating 
environment system), managing: any of the 
resources on a typical computer, including 
memory, files system, communications pbrts, 
storage devices, and higher level resources that 
may use any of these or. combinations of them: 


(a) a communications arrangement 


Communications port and Microsoft Internet 
Protocol stack that may optionally use Secure*. 
Socket Layer protocol or IPSEC packet 
security protocol, supplied with Microsoft 
Windows. 


(1) that securely receives a first control 
of a first entity external to said 
operating environment, and 


Rule or evidence contained in the manifest of a 
shared assembly, distributed by a first entity 
that can be used by the CLR, CLI or CCLR to 
determine permissions that may be needed to 
cause operations on a data item or resource 
controlled by another entity; shared assembly 
is tamper-protected and may be received using 
secure SSL or IPSEC protocol 


(2) securely receives a second control 
of a second entity external to said 
operating environment, said second 
entity being different from said first 
entity: and 


Rule specified in the manifest of a second 
shared (Tamper protected) assembly, that 
demands permissions of callers of its methods. 


^b) a protected processing environment, 
operatively connected to said 
communications arrangement that: 


CLR, CLI or CCLR, connected to (e.g.) 
communications port 


(1) [] securely processes, using at least 
one resource, a data item logically 
associated with said first and second 
controls, and 


CLR, CLI or CCLR uses type safety 
mechanisms, access controls, integrity 
detection, and separation of domains. Data 
item may be any data item that is managed by 
the second assembly, which may be a member 
of such assembly, and whose state or value 
may be accessible through an interface to other 
assemblies, and which is referenced by the first 
assembly. 


(2) 0 securely applies said first and 
second controls to manage said 
resource for controlling use of said data 
item. 


CLR, CLI or CCLR processes the demand for 
permissions from the second assembly, collects 
the evidence or processes the rule from the first 
assembly, and determines whether the first 
assembly has the permissions to use the 
resource to operate on the data item controlled 
bv the second assembly. 


>7. A system as in claim 36 wherein said 
>rotected processing environment is part of an 


Computer or electronic appliance running 
CLR, CLI or CCLR ' 
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end user electronic appliance. 

64. A system as in claim 36 wherein said 
communications arrangement receives said 
first and second controls from at least one 
remote location over at least one 

telecommunications link. ■ • 

75. A system as in claim 36 wherein said 
protected processing environment combines 
said first and second controls to provide a 
combined control arrangement. 


82. A system as in claim 36 wherein said 
communications arrangement independently 
receives said first and second controls at 

differenttimes 

88. A system as in claim 36 wherein at least 
one of the first control and second controls 
comprises at least one executable component 
and at least one data component. 


Shared assemblies are designed to be received 
remotely, e.g., over the internet. 


Arrangement consists of the stack frame and 
and the corresponding pTay of permission 
grants for assemblies on the stack, and the 
permission demanded by the second assembly. 

Assemblies, including controls, are designed 
for independent delivery. 


The second entity supplies an assembly with a 
demand procedure (executed by the CLR, CLI 
or CCLR) that includes reference to a specific 
attribute value (the data component), and the 
protected processing environment executes the 
executable component (demand) in a manner 
that is at least in part responsive to the data 
component (execution is in response to the 
security action supplied in the data item). 
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INTERTRUST TECHNOLOGIES CORP. v. MICROSOFT CORP. 


INTERTRUST INFRINGEMENT CHART 
FOR U.S. PATENT NO. 5,982,891 


36. 


Infringing Product: My Services 


A secure operating environment system 
for managing at least one resource 
comprising: 


Secure operating environment is the secure 
server for any .NET My Services service 
(e.g. Mv Calendar, Mv Inbox) 


a communications arrangement that 
securely receives 


Secure server receives communications 
formatted using the SOAP-SEC, the 
security extension to SOAP that is used by 
My Service servers to receive controls. 


a first control 


The first control is a roleTemplate 
associated with the service. The 
roleTemplate identifies specific actions 
(e.g. read, replace) that can be performed 
against a certain scope (resource or set of 
resources). 


of a first entity external to said operating 
environment, 


The first entity is the administrator of the 
server database, or other entity with 
authority over its content that sets up the 
roleTemplates and scopes. That entity is 
independent from and located remotely 
from the secure server. 


ind securely receives a second control 


A role element specified by a specific end 
user, which is securely received by the 
secure server using the SOAP-SEC 
protocol. . 


)f a second entity external to said 
>perating environment, said second entity 
>eing different from said first entity: 


The end user is located remotely from the 
secure server. 


ind a protected processing environment, 
>peratively connected to said 
x>mmunications arrangement, that: 


The protected processing environment is 
the .NET security service {authorization 
system) operating within the server. The 
server uses the SOAP-SEC 
communi cation protocol to receive 
controls. 


a) securely processes, using at least one 
esource, a data item logically associated 
vith said first and second controls, anjd 


"Securely processes" is performing the 
requested operation on secure server 
running .NET. The system will perform the 
requested operation ensuring that the user 
has no access to information outside the 
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scope computed. 


The resource is the server software and/or 
hardware used to process the two controls 
and user data. 

The first control is the rpleTempIate for the 
service. The second control^ the role 
element for an individual uiser. 

The data item is the end user's stored 
content (e.g. calendar, email inbox, etc.). 


b) securely applies said first and second 
controls to manage said resource for 
controlling use of said data item. 


The secure server determines the result 
scope (visible node set) for the operation 
that is computed from the role element and 
the roleTemplate. That result scope is used 
to manage the data item. 


14. A system as in claim 36 wherein said 
:ommunipations arrangement receives said 
irst and second controls from at least one 
emote location over at least one 
elecommunications link. 


The remote location is the site where the 
user's or administrator's application is 
running. 

The telecommunication link can be the 
Internet, intranet, VPN or other similar 
channels. 


r 5. A system as in claim 36 wherein said 
►rotected processing environment 
ombines said first and second controls to 
irovide a combined control arrangement. 


The role scope incorporating the role 
element and the role Template. 


12. A system as in claim 36 wherein said 
ommunications arrangement 
ndependently receives said first and 
econd controls at different times. 


Administrator and user controls will 
ordinarily be received at different times. 


5. A secure operating environment system 
s in claim 36 wherein said 
ommunications airangement also receives 
data item separately and at a different 
tme from at least one of said first control 
nd said second control. 


This is the normal case for .NET My 
Services. The user's content is normally 
stored and updated independently of the 
setting of scope elements, role elements and 
roleTemplates. 
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INTERTRUST TECHNOLOGIES CORP. v. MICROSOFT CORP. 
INTERTRUST INFJUNGEMENT CHART 
FOR tI.S. PATENT NO. 6,157,721 


Product Infringing: Windows CE for Automotive 


L A security method comprising: 


WCEfA is Microsoft Windows CE for Automotive, 
sometimes also known by its former name; AutoPC 2.0. 

With WCEfA an OEM can assign their device to a class 
that only accepts certain kinds of software. The device 
carTbe set to accept 1) any software with the corrptt 
processor/version 2) only certified software or 3) only 
software from the OEM or Microsoft. These Security (or 
Trust) levels also control to which kernel APIs and 
middleware APIs the software has access. 

Background: 

"Microsoft Software Install Manager (SIM), a 
component of WCEfA, allows you to control what can 
be installed on your device platform. You can define 
your platform as being open, closed or restricted to new 
installations, and SIM will enforce these designations." 
(D,pg.l) 

"Anything can be installed on an open platform, as long 
as the applications are compiled for the appropriate 
processor. At the other extreme, no third-party software 
can be installed on a closed platform. Only certified 
applications can be installed on a restricted platform." 
(D,pg.l) 

"By restricting installations to compliant applications, 
the risk of installing and using incompatible or harmful 
software is greatly reduced, while still keeping the 
device open for robust, quality applications that enhance 
the user experience." (F, pg.l) 

WCEfA also has a Security Layer whose purpose is to 
"Create an abstraction layer of security surrounding 1SV 
applications to limit and/or deny access to key Windows 
CE kernel API calls and WCEfA middleware APIs." 1, 


a) digitally signing a first load module with a 
irst digital signature designating the first load 
nodule for use by a first device class; 


X first load module is a WCEfA software component in 
a signed .PE file. The first device class is a device that 
only allows software designated as "restricted" (or 
higher) to be installed. "Restricted" software is software 
that has been certified. With restricted software, the 
device also implements a Security Layer functionality 
that limits the kernel and WCEfA API calls that the 
software can make. 


I! 
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"SIM Level: I = Restricted 
Description: Only properly certified CEI (WCEfA 
device installation) files can be installed on the device. 
Remote execution is restricted to executable^ with . 
master key. 

Key: Logo certified CEI file required. CEI files or EXEs 
with master keys permitted." (F,pg.l) . 

"The kernel loader calls it each time a module is loaded • 
by Windows CE. It returns one of the following values 
that determine the module's access to kernel resources: 

Value ' 
• Meaning 

OEM_CERTIFY_TRUST (2) 

The module is trusted by the OEM to perform any 

operation. 

OEM_CERTIFY_RUN (1) 

The module is trusted by the OEM to run but is 

restricted from making certain function calls. 

OEM_CERTIFYFALSE (0) 
The module is not allowed to run. 

"(H,pg.l) 

Digitally signing: "Before the kernel loads a file, it uses 
the OEMCertifyModule function to verify that the file 
contains the proper signature." (N, pg.I) 

"Signfile.exe: This tool signs an executable with a 
supplied private key. You can use the following 
command parameters with this tool....-s AttribString, 
specifies an optional attribute string to be included in the 
signature. For example, you could add a string to 
indicate the trust level of the application." (O. Pg. I) 

In the MSDN article Verifying the Signature, the sample 

code segment states 

"//the file has a valid signature 

// we expect the trust level to be returned as signed 

data... 

//case 'R' : dwTrustLevel - OEM CERTIFYJUJrT (N, 
Pg-2) 

"The WCEfA Security Layer isolates installed 
applications from making unrestricted kernel and 
WCEfA API calls. This allows the OEM to assign one of 
three levels of security to applications and drivers 
installed in RAM when they are loaded into the system. 
The three levels are Trusted. . . Restricted. . . , and 
I Blocked.. .On the systems level, the WCEfA Security 
IS - - * ' r ' 

- ii • 
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layer fits between ISV applications and isolates these 
software modules from having free access to all WinCE 
kernel calls and WCEfA middleware APIs" (I, pg. I) 

The developer submits their application for certification. 
If it passes, then the xei file (a form of cab file) receives 
a certification key from the certifier. The signed PE is 
within this xei file. 


(b) digitally signing a second load module with 
a second digital signature different from ihe 
first digital signature, the second digital 
signature designating the second load module 
for use by a second device class having at least 
one of tamper resistance and security level 
different from the at least one of tamper 
resistance and security level of the first device . 
class; . . ■ 


A second load module is a WCEfA software component 
is a signed PE file. The second device class with a 
different tamper resistance or security level is a device 
that is "Closed", that is, h will not allow third party to 
software to be installed. A closed device only allows 
trusted software to run. The Security Layer setting of 
"Trusted" allows the Microsoft and OEM software full 
access to kernel and middleware APIs. 

In the MSDN article Verifying the Signature, the sample 

code segment states 

"//the file has a valid signature 

// we expect the trust level to be returned as signed 

data... 

//case T : dwTrustLevel - OEM CERTIFYTRUST" 
(N.pg.2) 

"Signfile.exe: This tool signs an executable with a 
supplied private key. You can use the following 
command parameters with this tool..., -s AttribString, 
specifies an optional attribute string to be included in the 
signature. For example, you could add a string to 
indicate the trust level of the application. (O. Pg. 1) 

"SIM Level: 2 = Closed 

Description: Platform is limited to software supplied 
directly by OEM or Microsoft. Third-party applications 
cannot be installed. ... 

Key: Master key required for any install or remote 
execution." (F, pg.l) 

Related to the Security Layer, the Trusted level "is most 
likely reserved for MS and OEM applications and 
drivers." (If Pg- 0 

Whereas the xei files for certified software have a 
certification key (sometimes call MS Logo key), the xei 
flies from Microsoft or the OEM have a master key 
attached. ""Master key required for any install or remote 
execution "(F,p.gl) 


c) distributing the first load module for use by 
it least one device in the first device class: and 


First load module is the certified software from a third 
parry that will be run as pan of the "Restricted"^/ 
device class. 

"Once your application is complete, send the xei file to 


it 

Exhibit B « 
49 


1 

2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 


the organization that is performing validation or 
certification for the OEM. They would validate it, then 
either reject or return a xei that has been stamped with a 
certification key. You would then reproduce this xei file 
on CD-ROM or a compact flash card and distribute." (D, 
P-g5) 

"APCLoad compares the device SiM level against the 
xei flic certification key, and either allows the 
installation to proceed or prohibits it based on the 
outcome of this comparison." (D, pg. 2) 

"Security:. To achieve a high level of reliability, 
WCEfA is carefully designed to: 

Control the installation of certified and tested 
. . software and drivers. 
• - Limit the access of system services by installed 
module. 

Monitor the proper execution of software..." 
(G,pg.l) 


(d) distributing the second load module for use 
by at least one device in the second device 
class. 


The second load module is the certified software from 
the OEM or Microsoft that will be run as part of the 
"Closed" second device class. 

"You may need to change ROM components after your 
device ships, either to fix a problem, or to provide 
enhanced functionality. For this purpose, the OEM is 
given a CEIBuild that adds a master key to a xei file. 
CEI flies stamped with this master key can be installed 
on an open, closed or a restricted platform." (D, pg. 3) 

"Trusted: The application is registered as a completely 
trusted module and allowed full access to the kernel 
APIs and WCEfA APJs. This mode is mostly likely 
reserved for MS and OEM applications and drivers. 
Note that applications and drivers included in ROM are 
automatically given trusted status." (I, pg-1) 


References: 

D] hrrp://msdn.microsoft.com/Iibrary/defauIt.asp?url 

F] hn^://msoVi.microsoftxom/library/default.asp?url 

G] htt^^/msdn.microsoftxorri/library/default.asp?url : 

H] http://msd^.rhicrosoftxorn/library/default.asp?url 

I] ht^^/msdn.microsoftxorn/in>rary/defauU.asp?url 
N] htt^7/msdn.rnicrosoftxom/library/defauIt.asp?urI 
O] http^/msdn.microsoftxpni/library/defauIt.asp?url 


l=/library/en-us/dnceauto^tml/WinCAuto_SIM^asp 
: /Iibrary/en-us/apcguide/htm/ceibuildrev_8.asp 
l=/library/en-us/apcguide/hrrn/securityrev.asp 
l=/library/en-us/apcguide/htrn/securiryrev_7.asp 
=/library/en-us/apcgu ide/htm/reliabil ityrev_3 .asp 
l=/library/en -us/wcedsn4 0/htm/cgcon Verify ingS ignarurcasp 
l=/library/en-us/wceoem/htm/os - secur_6.asp 
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JNTERTRUST TECHNOLOGIES CORP. v. MICROSOFT CORP. 
INTERTRUST INFRINGEMENT CHART 
FOR U.S. PATENT NO. 6,157,721 


S. 


Product infringing: Windows Hardware 
Quality Lab certification services/and * . 
operating system products that support 
driver signature technology. 


A software verifying method comprising: 


Microsoft encourages manufacturers to 
have their device drivers tested and signed. 
For example, only signed drivers will ship 
"in-the-box." Also, Microsoft's driver 
ranking prefers signed drivers to unsigned 
drivers. 

Microsoft Web Page - Can't Find a Test 
Category for Your Driver? 
WHQL's long : term objective is to be able 
to digitally sign all drivers. Although we do 
not currently have test programs for certain 
driver types, such as specialized device 
drivers and software filter drivers, WHQL 
is investigating a long term solution to 
expand the categories of drivers tested 
under Windows 2000 and ultimately all 
Windows operating systems. We are 
already formulating a test program for anti- 
virus file system filters, and plan to address 
other file system filter drivers as soon as 
the initial program is in place. 


a) testing a load module 


avine at least one specification associated 


The driver will be tested for each version of 
the operating system it supports and against 
the device class specification that apply to 
the device's class. 

The driver package is a load module. A 
driver package contains one or more of the 
following files: 

A device setup information file (INF file) 

A driver catalog (.cat) file 

One or more optional co-installers 

Microsoft operates the Window Hardware 
Quality Lab, which tests drivers submitted 
by driver manufactures. 

The manufacturer can test their own driver 
using the Microsoft testing kit and submit 
the test results to WHQL when requesting a 
signature. Additionally^ Microsoft or a 
testing facility working with Microsoft can 
perform the testing. 


The manufacturer- written INF file, which 


■ 'i 
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293482.02 


therewith* 


the specification describing one or more 
functions performed by the load module; 


(b) verifying that the load module satisfies 
the specification; and 


is part of the driver package, is a. 
specification. Microsoft Windows drivers 
must have an INF file in order to be 
installed. __ 


The INF Version section specifies its 
device class. One use of the device class is 
to identify the. specific Windows 
compatibility specification that relate to the 
device class. These specifications will vary 
by device class in part because the function 
ofeach device can vary among class. The 
INF incorporates by reference the . 
Microsoft supplied device class-specific 
specification by identifying its class in the 
INF. 

The INF can include operating system 
"decorating" to specify the operating 
system architecture, major and minor 
version, product and suite the driver is 
intended for and can further use this 
decorating to specify what operating 
systems for which it is not intended. 
Because the functionality of each of the 
operating systems may vary the driver must 
be tested for each applicable operating 
system. 

Qualification Service Policy Guide - 
Hardware Category Policies 

You must select the correct hardware 
category for your device. If you select the 
wrong hardware category for your device, 
your submission will fail. For example, if 
you have a storage/hard drive device, but 
you select storage/tape drive as your 
hardware category, your submission will 
fail. 

Windows XP HCT 10.0 Q & A - Windows 
XP Logos 

Q: Which "Designed for Windows XP" 
logos are available for my product? 
A: Devices and systems qualify for a 
"Designed for Windows" logo after passing 
testing with the appropriate WHQL test kit 
on all operating systems specified by the 
logo. "Designed for Windows'* Logos for Device 
and System Programs lists which logos are 
available for each type of product. 


The Microsoft WindowsXP Hardware 
Compatibility Test (HCT) kit version 10.0 
includes the tests, test documentation, and 
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(c) issuing at least one digital certificate 
attesting to the results of the verifying step. 


submission processes that are required to 
participate in the Microsoft Windows Logo 
Program for Hardware for the Windows 
XP Professional operating system. To 
qualify to use the "Designed for Windows" 
logo for hardware, products must pass 
testing with the Microsoft Windows HCT 
kit The HCT kits are organized by. 
hardware type. * ' ' 

As mentioned above, the manufacturer can 
test their own driver using the Microsoft 
testing kit and submit the test results to 
WHQL when requesting a signature. 
Additionally, Microsoft or a testing facility 
working with Microsoft can perform the 

testing. ; 

When a driver package passes WHQL 
testing, WHQL generates a separate CAT 
file containing a hash of the driver binaries 
and other relevant information. WHQL 
then digitally signs the CAT file using 
Digital Signature cryptographic technology 
and sends it to the vendor. Driver signing 
does not change the driver binaries or the 
INF file submitted for testing. 

Microsoft uses digital signatures for device 
drivers to let users know that drivers are 
compatible with Microsoft Windows XP, 
Windows 2000, and Windows Me. A 
driver's digital signature indicates that the 
driver was tested with Windows for 
compatibility and has not been altered since 
testing. 
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Infringing products include Office 2003 and 
included applications, and Server 2003, 
including Microsoft hooted RMS Service using 
Passport 


\ first protected processing environment 
c omprising: 


A personal computer running Windows XP, 
Windows 2000, or Windows 2003 


t first tamper resistant barrier having a first 
lecurity level, and 


The tamper resistant barrier is the Office 2003 
IRM client environment and includes the 
signed digital certificate identifying the user. 

If the certificate is tampered with, or if certain, . 
sensitive IRM processes or modules are 
debuggeid or tampered with, the system will 
cease to operate. 

The first security level is the "Security Level" 
which has been selected for a particular Office 
Application, e.g.. Word. 


t least one arrangement within the first 
amper resistant barrier that prevents the first 
►rotected processing environment from 
xecuting the same load module accessed by a 
econd protected processing environment 
taving a second tamper resistant barrier with a 
econd security level different from the first 
ecurity level. 


The arrangement that prevents a load module 
from running in one PPE and not in another is 
the type and characteristics of a particular Load 
Module (VBA program within a document or 
add-in); i.e., signed, script author, code 
capabilities, etc., and the "Security Level" 
settings. 


,.n 
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18. 


^ method for protecting a first computing 
rrangement surrounded by a first tamper 
esistant barrier having a first security level, 
be method including: 


Infringing products include Office 2003. and 
included applications, and Server 2003, 
including Microsoft hosted RMS Service using 
Passport 


The first computing arrangement with a tamper 
resistant barrier is the Office 2003 IRM client 
environment and includes the signed digital 
certificate identifying the user. 

If the certificate is tampered with, or if certain, 
sensitive IRM processes or modules are 
debugged or tampered with, the system will 
cease to operate. 

The computing arrangement is being protected 
from; for example, viruses and malicious code. 

The first security level is the "Security Lever 
which has been selected for a particular Office 
Application, e.g.. Word. ; 


reventing the first computing arrangement 
om using the same software module 
rcessible by a second computing arrangement 
aving a second tamper resistant barrier with a 
scond security level different from the first 
jcurity level. 


The arrangement that prevents a load module 
from running in one computing arrangement 
and not in another is the type and 
characteristics of a particular software module 
(VBA program within a document or add-iri); 
i.e., signed, script author, code capabilities, 
etc., and the "Security Level" settings. 


li 
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Infringing products include Office 2003 and 
included applications, and Server 2003, 
including Microsoft hooted RMS Service using 
Passport 


i\ protected processing environment 
comprising: 


A personal computer running Windows XP, 
Windows 2000, or Windows 2003 


a first tamper resistant barrier having a first 
security level, 


The first tamper resistant barrier is the Office 
2003 IRM client environment and includes the 
signed digital certificate identifying the user. If 
the certificate is tampered with, or if certain, 
sensitive IRM processes or modules are . 
debugged or tampered with, the system will, 
cease to operate. 

The first security level is the "Security Level" 
which has been selected for a particular Office 
Application, e.g.. Word. 


i first secure execution space, and 


The secure execution space is process space 
allocated by the operating system for the 
Microsoft Office host application to run. This 
host application (e.g., Word) executes the VBA 
code within this process space. 

This execution space (application) is secure 
because the IRM environment takes steps to 
insure that it is "trusted", the application is 
signed, and the document which includes the 
VBA code is protected by IRM policy and then 
encrypted and signed. , 


it least one arrangement within the first 
amper resistant barrier that prevents the first 
iecure execution space from executing the 
;ame executable accessed by a second secure 
:xecution space having a second tamper 
esistant barrier with a second security level 
iifTerent from the first security level. 


The arrangement that prevents a load module 
from running in one computing arrangement 
and not in another is the type and 
characteristics of a particular software module 
(VBA program within a document or add-in); 
i.e., signed, script author, code capabilities, 
etc., and the "Security Level" settings. 
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34. 


A protected processing environment 


Product Infringing: Microsoft Common Language 
RuntimeandASP.NET • ■ . 


somprising: 

a first tamper resistant barrier having a 
first security level, 


Microsoft Common Language Runtime and 
ASP.NET 


TAMPER RESISTANT BARRIER 
The first tamper resistant barrier is the application 
domain in the CLR. The runtime hashes the 
contents of each file loaded into the application ■ 
domain and compares it with the hash value in the 
manifest. If two hashes don't match, the assembly 
fails to load.[l] 

Also "Code running in one application cannot 
directly access code or resources from another 
application. The common language runtime 
enforces this isolation by preventing direct calls 
between objects in different application domains. 
Objects that pass between domains are either 
copied or accessed by proxy."[2] 

SECURITY LEVELS 

The security levels of the' application domain if 
different by setting the trust level assigned to an 
outside application using the "trust" element in the 
web.config for the ASP.NET application. 
Syntax- 

<trust level="Full/High/Low/None" 
originUrl="url"/> 

Example-. 

<tnist lcvd="High" 

originUri=hnp://www.SomeOtherCompany.com/defaul 
t.aspx*> 

[7] 


i first secure execution space, and 


The application domain is the execution space for a 
particular application. 


t least one arrangement within the first 
unper resistant barrier that prevents the 
rst secure execution space from 
xecuting the same executable accessed 
y a second secure execution space 
aving a second tamper resistant barrier 
n\h a second security level different from 
ie first security level. 


The second secure execution space is another 
application domain that has a different trust level for 
an outside application. 

If second app domain gives Full trust to the outside 
application; whereas the first one doesn't, the first 
app domain won't be able to execute the application 
thai requires full trust permission. 


References: 

in 
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www.microsoft.com/germany/ms/msdnbibIio/do 

tnetrk/doc/assembly.doc 

[2] msdn.Microsoft.com/library/en- 

us/cpguide/html/ 

cpconapplicationdomainsoverview.asp?frame=tr 
ue 

[ 7] LaMacchia,etc, .NET Framework Securi ty. 
Addision- Wesley, 2002 
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34. 


A protected processing environment 
comprising: 


a first tamper resistant barrier having a first 
security level, 


mmmmmm/mmmmm 


Product Infringing: Products containing 
Microsoft Common Language Runtime or 
Compact Common Language Runtime and 
products implementing the Common Language 
Infrastructure specification, 


Microsoft Common Language Runtime and 
.NET Framework SDK: •' - 


TAMPER RESISTANT BARRIER 
The first tamper resistant barrier is the 
application domain in the CLR The runtime 
hashes the contents of each file loaded into the 
application domain and compares it with the . * 
hash value in the manifest. If twb hashes don't 
match, the assembly fails to load. [1] 

Also "Code running in one application cannot 
directly access code or resources from another 
application. The common language runtime 
enforces this isolation by preventing direct 
calls between objects in different application 
domains. Objects that pass between domains 
are either copied or accessed by proxy '."[2] 

SECURITY LEVELS 

Application domains have different security 
levels by setting security policy of the 
application domain programmatically. [3] 
'7/ has different security based on code-based 
security model of.NET. Administrators and 
hosts use code-access security to decide what 
code can do, based on characteristics of the 
code itself regardless of what user is executing 
the code. The code characteristics are called 
evidence and can include the Web site or zone 
from which the code was downloaded, or the 
digital signature of the vendor who published 
the code. " 

When the security manager needs to 
determine the set of permissions that an 
assembly is granted by security policy, it starts 
with the enterprise policy level. Supplying the 
assembly evidence to this policy level will 
result in the set of permissions granted from ~ 
that policy level The security manager 
typically continues to collect (he permission 
sets of the policy levels below the enterprise 
policy [including the app domain! in the same 
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a first secure execution space, and 


at least one arrangement within the first tamper 
resistant barrier that prevents the first secure 
execution space from executing the same 
executable accessed by a second secure 
execution space having a second tamper 
resistant barrier with a second security level 
different from the first security level. 


fashion. These permission sets are then 
intersected to generate the policy system 
permission set for the assembly. All levels must 
allow a specific permission before it can make 
it into the granted permission set for the 
assembly " . 

Example of granted permission sets from a 
policy- 

Condition: All code. Permission Set: Nothing 

Condition: Zone: Internet, Permission Set: Internes Condition: URL: 
www.mpnash.edu.oK Permission Set: MonasbPSet 
Condition: Strong Name: m-Commerce. Permission Set: m~ • 
CommercePSet [4] 

Another difference in security levels can be 
whether the verification process is turned off or 
on, "Managed code must be passed through a 
verification process before it can be run 
(unless the administrator has granted 
permission to skip the verification). The 
verification process determines whether the 
code can attempt to access invalid memory 
addresses or perform some other action that 
could cause the process in which it is running 
to fail to operate properly. Code that passes 
the verification test is said to be type-safe. The 
ability to verify code as type-safe enables the 
common language runtime to provide as great 
a level of isolation as the process boundary, at 
a much lower performance cost" [5] 


The application domain is the execution space 
for a particular application. 


The second secure execution space is another 
application domain that has a different security 
pol icy than the first. 

If second app domain's security policy doesn't 
give any permission to code from internet 
zone, but first app domain does, then the code 
would run in first app domain and not in 
second. [6] 


References: 

in 

www.microsoft.com/germany/ms/msdnbibl 

io/dotnetrk/doc/assembly.doc 

[2] msdn.Microsoft.com/library/en- 

us/cpguide/hlml/ 

cpconapplicationdomainspverview.asp?fra* 
me=true ; ~ *" « " 
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[3] LaMacchia.etc. .NET Framework 
Securi ty. Addision-Wesley, 2002, p.l 13 
[4] Watkins, Demien, "An Overview of 
Security in the .NET Framework", from 
MSDN Library, January 2002 
[5] same as [2] 

[6] msdn.Microsoft.com/library/en- 
. us/cpguide/html/ 
• cpconapplicationdomainlevelsecuritypolicy 

.asp?frame=true 
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^ method for protecting a first computing 
irrangement surrounded by a first tamper 
esistant barrier having a first security level, 
he method including: 


Infringing products include Office 2003 and 
included applications, and Server 2003, 
including Microsoft hosted RMS Service using 
Passport 


The first computing arrangement surrounded by 
a tamper resistant barrier is the Office 2003 
IRM client environment and includes the 
signed digital certificate identifying the user. If 
the certificate is tampered with, or if certain, 
sensitive IRM processes or modules are 
debugged or tampered with, the system will 
cease to operate. 

The first security level is the "Security Level" 
which has been selected for a particular Office 
Application, e.g.. Word. 


reventing the first computing arrangement 
rom using the same software module accessed 
y a second computing arrangement having a 
econd tamper resistant barrier with a second 
ecurity level different from the first security 
;vel. 


The computing arrangement that prevents a 
software module from running in one 
computing arrangement and not in another is 
the type and characteristics of the particular 
software module (VBA program within a 
document or add-in); i.e., signed, script author, 
code capabilities, etc.* and the "Security Level" 
settings. 
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Product Infringing: Windows Media Rights 
Manager and Windows Media Player 


A system including : 


(a) a first apparatus including, 


Consumer's computer, as shown in WMRM 

SDK 


(1) user controls, 


Consumer's computer, as shown in WMRM 

SDK . 


(2) a communications port, 


Consumer's computer, as shown in WMRM 

SDK " 


(3) a processor, 


Consumer's computer, as shown in WMRM 
SDK 


(4) a memory storing: 


Consumer's computer, as showi) in WMRM 

SDK ' 


(i) a first secure container containing 
a governed item, the first secure 
container governed item being at 
least in part encrypted; the first 
secure container having been 
received from a second apparatus: 


Secure container (packaged Windows Media 
file), received by consumer's computer from 
"Content provider" ( WMRM SDK, Step 3), 
which contains encrypted governed item 
("Encrypted content") 


(ii) a first secure container rule at least 
in part governing an aspect of 
access to or use of said first secure 
container governed item, the first 
secure container rule [sic], the first 
secure container rule having been 
received from a third apparatus 
different from said second 
a pparatus; and 


Rights portion of signed license, received by 
consumer's computer from "License issuer" 
(WMRM SDK, Step 9) 


(5) hardware or software used for 
receiving and opening secure 
containers, said secure containers each 
including the capacity to contain a 
governed item, a secure container rule 
being associated with each of said 
secure containers: 


Windows Media Player and Windows Media 
Rights Manager 


(6) a protected processing environment at 
least in part protecting information 
contained in said protected processing 
environment from tampering by a user 
of said first apparatus, said protected 
processing environment including 
hardware or software used for 
applying said first secure container 
rule and a second secure container rule 
in combination to at least in pan 
govern at least one aspect of access to 
or use of a governed item contained in 
a secure container: and 


1 st and 2nd rules consist of any two valid rules 
as specified in the Window Media Rights 
Manager SDK; protected processing 
environment includes Windows Media Rights 
Manager and Windows processes for 
protecting operation of Windows Media Rights 
Manager. Licenses can be used to convey 
multiple rules. 


(7) hardware or software used for 


Any hardware or software employed in 


Exhibit B 


transmission of secure containers to 
other apparatuses or for the receipt of 
secure containers from other 
apparatuses. 


transmitting Windows Media files, including 
for example consumer's computer's 
communication port and Windows Media 
Player ( WMRM SDK! Step ^ _ 
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Infringing products include Office 2003 and 
included applications, and Server 2003, 
including Microsoft hosted RMS Service using 
Passport 


\ system including: 


i first apparatus including, 
jser controls, 
i communications port, 
t processor, 
i memory storing: 


A device with user controls, a communications 
port, a processor and memory. For example, 
the user controls may be a keyboard and 
mouse, the conynunications port may be a NIC 
card with an Ethernet port, the processor may 
be a CPU, and the memory rnay be a hard-drive 
or RAM. 


i first secure container containing a governed 
tern, the first secure container governed item 
>eing at least in part encrypted; the first secure 
container having been received from a second 
ipparatus; 


An encrypted I RM- governed email received 
from a remote computer. The encrypted IRM- 
govemed email contains an encrypted IRM- 
governed email message. 


t first secure container rule at least in part 
governing an aspect of access to or use of said 
irst secure container governed item, the first 
iecure container rule, the first secure container 
ule having been received from a third 
ipparatus different from said second 
ipparatus; and 


The first secure container rule is received from 
the RMS server in the form of a use license. 

This use license contains rules generated by the 
RMS server specifically for the user (or user's 
group) 


lardware or software used for receiving and 
>pening secure containers* 

aid secure containers each including the 
capacity to contain a governed item, a secure 
container rule being associated with each of 
;aid secure containers; 


i protected processing environment at least « 
>art protecting information contained in said 
>rotected processing environment from 
ampering by a user of said first apparatus, 

;aid protected processing environment 
ncluding hardware or software used for 
applying said first secure container rule and a 
lecond secure container rule in combination to 
it least in nart govern at least one asnect of 


The RM-enabled device contains hardware or 
software for receiving and opening secure 
emails. 

The secure email has the capacity to contain an 
IRM-governed email message, with a rule 
being associated with each email. 

The rules associated with the secure emails are 
rules that come as part of the original email as 
well as rules that come back from the RMS. 


in 


Protected information on the RM-enabled 
device is protected by the use of at least 
cryptographic techniques. 


The rule governing the email works together 
with an additional rule to determine what 
access to or use (if any) are allowed with 
respect to the IRM-governed email message. 
Fonexamnle. the additional rule mav he 
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access to or use of a governed item contained 
in a secure container; and 


hardware or software used for transmission of 
secure containers to other apparatuses or for 
the receipt of secure containers from other 
apparatuses. 


received together with the rule in the use 
license. • 

The device includes hardware or software used 
for transmitting or receiving secure emails. For 
example, RM-enabled OUTLOOK is designed 
.to transmit and receive encrypted IRM- 
governed emails to/from other devices. . 
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Infringing products include Office 2003 and 
included applications, and Server 2003, 
including Microsoft hosted RMS Service using 
Passport 


\ system including: 


i first apparatus including, 
jser controls, 
i communications port, 
i processor, 
i memory storing: 


A device with user controls, a communications 
port, a processor, and memory. For example, 
the user controls may be a keyboard and 
mouse, the communications port may be a NIC 
card with an Ethernet port the processor may 
be a CPU, and the memory may be a hard-drive 
or RAM. • 


i first secure container containing a governed 
tern, the first secure container governed item 
>eing at least in part encrypted; the first secure 
:ontainer having been received from a second 
apparatus; 


The first secure container is an encrypted IRM- 
protected document. 

This encrypted IRM-governed document is, for 
example, received from a remote computer, as 
an attachment to an IRM-governed email or 
downloaded from a document server or web 
site. 


i first secure container rule at least in part 
governing an aspect of access to or use of said 
irst secure container governed item, the first 
secure container rule, the first secure container 
■ule having been received from a third 
ipparatus different from said second 
ipparatus; and 


The first secure container rule is received from 
the RMS server in the form of a use license. 

This use license contains rules generated by the 
RMS server specifically for the user (or user's 
group). 


hardware or software used for receiving and 
)pening secure containers, 

;aid secure containers each including the 
capacity to contain a governed item, a secure 
:ontainer rule being associated with each of 
;aid secure containers; 


The RM-enabled device contains hardware or 
software for receiving and opening secure 
documents. 

The secure documents have the capacity to 
contain IRM-governed content, with a rule 
being associated with each secure document. 

The rules associated with said secure 
documents are the rules that come as part of the 
originally received document as well as rules 
that come back from the RMS server. 


i protected processing environment at least in 
3an protecting information contained in said 
srotected processing environment from 
ampering by a user of said first apparatus, 


Protected information on the RM-enabled 
device is protected by the use of at least 
cryptographic technique. 

The rule governing the document works 
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said protected processing environment 
including hardware or software used for 
applying said first secure container rule and a 
second secure container rule in combination to 
at least in part govern at least one aspect of 
access to or use of a .governed item contained 
in a secure container; and ' '. • 


hardware or software used for transmission of 
secure containers to other apparatuses or for 
the receipt of secure containers from other 
apparatuses. 


together with an additional rule to determine 
what access to or use (if any) are allowed with 
respect to the IRM-governed document. For 
example, the additional rule may be associated 
with an email to which the document was 
attached, or received together with the rule in . 
the use license. ... 

The device includes hardware or software used 
for transmitting or receiving secure documents. 
For example, RM-enabled OUTLOOK is 
designed to transmit and receive'to/from other 
. devices emails with IRM-governed documents 
attached thereto. • 


' •ii 
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Infringing products include Office 2003 and 
included applications, and Server 2003, 
including Microsoft hosted RMS Service using 
Passport • 


V system including: 


l first apparatus including, 
tser controls, 
communications port, 
processor, 

memory storing: 


A device with user controls, a communications 
port, a processor and memory. For example, 
the user controls may be a keyboard and ' 
mouse, the communications port may be a NIC 
card with an Ethernet port, the processor may 
be a CPU, and the memory may be a hard-drive 
or RAM. 


first secure container containing a governed 
em, the first secure container governed item 
eing at least in part encrypted; 


The first secure container containing a 
governed item is an IRM protected email. 

Both the email and attachment are IRM 
protected, each having their own rules, each 
being encrypted. 


first secure container rule at least in part 
oveming an aspect of access to or use of said 
rst secure container governed item; and 


The rule governing the email (a first secure 
container rule) governs said first secure 
container governed item. 


second secure container containing a digital 
srtificate; 


The second secure container is the IRM 
protected attachment's derived license request 
object. 

The license request object contains the 
Publishing license and a signed digital 
certificate. 


irdware or software used for receiving and 
>ening secure containers, 

id secure containers each including the 
ipacity to contain a governed item, a secure 
>ntainer rule being associated with each of 
id secure containers: 


The RM (IRM) enabled computer has software 
for receiving and opening secure containers. 

The IRM secure containers have capacity to 
contain a governed item, with a secure 
container rule being associated with each of 
said secure containers. 


protected processing environment at least in 
ut protecting information contained in said 
otected processing environment from 
mpering by a user of said first apparatus, 

id protected processing environment 
eluding hardware or software used for 


Protected information on the RM-eniabled 
computer is protected by the use of at least 
cryptographic techniques. 


The rules governing the email itself ( first 
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applying said first secure container rule and a 
second secure container rule in combination to 
at least in part govern at least one aspect of 
access to or use of a governed item contained 
I in a secure container: and 


secure container rule) and the rules governing 
the attachment work together to determine what 
access to or use (if any) will be allowed with 
respect to the governed item. 


hardware or software used for transmission of 
secure containers to other apparatuses or for 
the receipt of secure containers from other 
apparatuses. 


IRM-enabled applications, e.g., OUTLOOK, 
are designed to transmit and receive RM 
secured containers to/from other computers. 


293462.02 
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3. 

Infringing products include Office 2003 and 
included applications, and Server 2003, 
including Microsoft hosted RMS Service using 
Passport 

A system including: 


a first apparatus including, 

user controls, 

a communications port, 

a processor, 

a memory storing: 

A device with user controls, a communications 
port, a processor and memory. For example, . 
the user controls may be a keyboard and 1 
mouse, the communications port may be a NIC 
card with an Ethernet port, the processor may 
be a CPU, and the memory may be a hard-drive 
or RAM. 

a first secure container containing a governed 

JICII1, UJC lliol oCUUJC lAJlJldJIlCI gUVCJJJCU JLC1I1 

being at least in part encrypted; 

The first secure container containing a 
govcmcu ncm is an irvjvi proieciea uocumeni, 
which is an attachment within an IRM 
protected email message. The governed item is 
the document's content. 

Both the email message and attachment are 
encrypted and have associated usage rules due 
to IRM protection. 

a first secure container rule at least in part 
governing an aspect of access to or use of said 
first secure container governed item: and 

A use license for the IRM protected document 
specifies rules governing access to or use of 
said first secure container governed item. 

18 
19 
20 
21 
22 
23 

a second secure container containing a digital 

The second secure container is the IRM 

The IRM protected attachment includes a 
publishing license and an owner certificate, 
both of which are signed XrML digital 
certificates. 

The attachment (including embedded 
certificates) is contained within the IRM 
protected email message (said second secure 
container). 

24 
25 
26 
27 
28 

hardware or software used for receiving and 
opening secure containers, 

said secure containers each including the 
capacity to contain a governed item, a secure 
container rule being associated with each of 
said secure containers: 

The RM (IRM) enabled computer has software 
for receiving and opening secure containers. 

The IRM secure containers have capacity to 
contain a governed item, with a secure 
container rule being associated with each of 
said secure containers. 

a protected processing environment at least in 
part protecting information contained in said 
nrotecteid processing environment from 

Protected information on the RM-enabled 
computer is protected, by the use of at least 
cryptographic techniaues. ~ . 
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tampering by a user of said first apparatus, 

said protected processing environment 
including hardware or software used for 
applying said first secure container rule and a 
second secure container rule in combination to 
at least in part govern at least one aspect of 
access to or use of a governed item contained 

in a secure container; and - - m 

hardware or software used for transmission of 
secure containers to other apparatuses or for 
the receipt of secure containers from other 
apparatuses, 


4. A system as in claim 3, . 

said memory storing a rule associated with 
said second secure container, said rule 
associated with said second secure container at 
least in part governing at least one aspect of 
access to or use of said digital certificate. 


The rules governing the attachment (first secure 
container rule) and the rules governing the 
email message (second secure container rule) 
work together to determine what access to or 
use (if any) will be allowed with respect to the 
governed item. 

RM-enabled applications, e.g., OUTLOOK, are 
designed to transmit and receive RM secured 
containers to/from other computers. 


All parts of the attachment (including 
embedded signed XrML licenses/certificates) 
are protected by the enclosing email message 
and governed by the associated email rules 
(second secure container ruleV • 
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CLAIM LANGUAGE 


CLAIM OF INFRINGEMENT 


Infringing products include Office 2003 and 
included applications, and Server 2003, 
including Microsoft hosted RMS Service using 
Passport . 


\ system including: 


t first apparatus including, 
lser controls, 
i communications port, 
i processor, 

i memory storing: 


A device with user controls, a cofnmunications 
■port, a processor and memory. For example, 
the user controls may be a keyboard and 
mouse, the communications port may be a NIC 
card with an Ethernet port, the processor may 
be a CPU, and the memory may be a hard-drive 
or RAM. 


i first secure container containing a governed 
tern, the first secure container governed item 
>eing at least in part encrypted; 


first secure container rule at least in part 
loverning an aspect of access to or use of said 
irst secure container governed item; and 


first secure container containing a governed 
item is an IRM protected email. 

Both the email and attachment are IRM 
protected, each having their own rules, each 
being encrypted. 


The rule governing the email (a first secure 
container rule) governs said first secure 
container governed item. 


second secure container containing a digital 
ignature, the second secure container being 
ifferent from said first secure container, 


The second secure container is the IRM 
protected attachment's derived license request 
object. 

The license request object contains the 
Publishing license and a signed digital 
certificate. 


ardware or software used for receiving arid 
pening secure containers, said secure 
ontainers each including the capacity to 
ontain a governed item, a secure container 
jle being associated with each of said secure 
ontainers; 


protected processing environment at least in 
art protecting information contained in said 
rotected processing environment from 
impering by a user of said first apparatus, 

aid protected processing environment 
icluding hardware or software used for 
nnlving said first secure container rule and a 


The RM (IRM) enabled computer has software 
for receiving and opening secure containers. 

The IRM secure containers have capacity to 
contain a governed item, with a secure 
container rule being associated with each of 
said secure containers. 


Protected information on the RM -enabled 
computer is protected by the use of at least 
cryptographic techniques. 


The rules governing the email itself (first 
secure container ru\e\ and the rules governing 


• : \\ 
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second secure container rule in combination to 
at least in part govern at least one aspect of 
access to or use of a governed item contained 

in a secure container: and , 

hardware or software used for transmission of 
secure containers to other, apparatuses or for 
the receipt of secure containers, from other 
a pparatuses. • 


the attachment will work together to determine 
what access to or use (if any) will be allowed 
with respect to the governed item. 

RM-enabled applications, e.g., OUTLOOK, are 
designed to transmit and receive RM secured 
containers to/from other computers. 
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•41 


Infringing products include Office 2003 and . 
included applications, and Server 2003, 
including Microsoft hosted RMS Service using 
Passport ' 


A system including: 


a first apparatus including, 
user controls, 
a communications port, 
a processor, 
a memory storing: 


A device with user controls, a communications 
port, a processor and memory. For example, 
the user controls may be a keyboard and 
mouse, the communications port may be a NIC 
card with an Ethernet port, the processor may 
be a CPU, and the memory may be a hard-drive 
or RAM. 


a first secure container containing a governed 
item, the first secure container governed item 
being at least in part encrypted; 


first secure container containing a governed 
item is an IRM protected email. 

Both the email and attachment are IRM 
protected, each having their own rules, each 
being encrypted. 


a first secure container rule at least in part 
governing an aspect of access to or use of said 
first secure container governed item; and 


Hie rule governing the email (a first secure 
container rule) governs said first secure 
container governed item. 


a second secure container containing a digital 
signature, the second secure container being 
different from said first secure container; • 


The second secure container is the IRM email 
attachment. 

This attachment and its publishing license are 
signed. 


hardware or software used for receiving.and 
opening secure containers, said secure 
containers each including the capacity to 
contain a governed item,*a secure container 
rule being associated with each of said secure 
containers; 


The RM (IRM) enabled computer has software 
for receiving and opening secure containers. 

The IRM secure containers have capacity to 
contain a governed item, with a secure 
container rule being associated with each of 
said secure containers. 


a protected processing environment at least in- 
part protecting information contained in said 
protected processing environment from 
tampering by a user of said first apparatus, 

said protected processing environmem 
including hardware or software, used for 
annlving said first secure container rule and a 


Protected information on the RM-enabled 
computer is protected by the use of at least 
cryptographic techniques. 


The rules governing the email itself (first 
secure container ru\e\ and the rules governing 
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second secure container rule in combination to 
at least in part govern at least one aspect of 
access to or use of a governed item contained 

in a secure container: and 

hardware or software used for transmission of 
secure containers to other apparatuses or for 
the receipt of secure containers from other 
a pparatuses. i_j 


the attachment work together to determine what 
access to. or use (if any) will be allowed with 
respect to the governed item. 

RM-enabled applications, e.g., OUTLOOK,are 
designed to transmit and receive RM secured 
containers to/from other computers. 
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5 li5. 
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Infringing products include Office 2003 and 
included applications, arid Server 2003, 
including Microsoft hosted RMS Service using 
Passport 


A system including: 


g a first apparatus including, 
2 I user controls, 
j q l a communications port, 
j j i|. a processor, 
12 II a memory storing: 


A device with user controls, a communications 
port, a. processor and memory. For example, 
the user controls may be a keyboard and 
mouse, the communications port may be a NIC 
card with an Ethernet port, the processor may 
be a CPU, and the memory may be a hard-drive 
or RAM. 


13 
14 
15 
16 
17 
18 
19 

20 

21 
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25 
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a first secure container containing a governed 
item, the first secure container governed item 
being at least in part encrypted; 


The first secure container containing a 
governed item is an IRM protected document, 
which is an attachment within an IRM 
protected email message. The governed item is 
the document's content. 

Both the email message and attachment are 
encrypted and have associated usage rules due 
to IRM protection. 


a first secure container rule at least in part 
governing an aspect of access to or use of said 
first secure container governed item: and 


A use license for the IRM protected document 
specifies rules governing access to or use of 
said first secure container governed item. 


a second secure container containing a digital 
signature, the second secure container being 
different from said first secure container; 


The second secure container is the IRM 
protected email message. 

The IRM protected attachment includes a 
publishing license and an owner certificate, 
both of which are signed XrML digital 
certificates. 

The attachment (including embedded 
certificates) is contained within the ERM 
protected email message (said second secure 
container). _ 


hardware or software used for receiving and 
opening secure containers, said secure 
containers each including the capacity to 
contain a governed item, a secure container 
rule being associated with each of said secure 
containers: . 


The RM (IRM) enabled computer has software 
for receiving and opening secure containers. 

The IRM secure containers have capacity to 
contain a governed item, with a secure 
container rule being associated with each of 
said secure containers. 


a protected processing environment at least in 
I nart protecting information contained in said 


Protected information on the RM-enabled- . 
computer is protected hv the use of at least 
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protected processing environment from 
tampering by a user of said first apparatus, 

said protected processing environment 
including hardware or software used for 
applying said first secure container rule and a 
second secure container rule in combination to 
at least in part govern at least one aspect of 
access to or use of a governed item contained 

in a secure container; and ■ • 

hardware or software used for transmission of 
secure containers to other apparatuses or for 
the receipt of secure containers from other 

apparatuses. 

6. A system as in claim 5, 

said memory storing a rule at least in part 
governing an aspect of access to or use of said 
digital signature. 


cryptographic techniques. 


The rules governing the attachment (firpt secure 
container rule) and the rules governing the 
email message (second secure container rule) 
work together to determine what access, to or 
use (if any) will be allowed with respect to the 

governed item. 

RM-enabled applications, e.g., OUTLOOK, are 
designed to transmit and receive RM secured 
containers to/from other computers. 


All parts of the attachment (including 
embedded signed XrML licenses/certificates) 
are protected by the enclosing email message •• 
and governed by the associated email rules 
(second secure container rule). 


Ml 
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5 II 28 - 
6 

7 || A system including: 
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g a first apparatus including; 
2 J user controls, 
10 I a communications port, 
j j ■ a processor, 
j 2 I a memory containing a first rule, 

13 
14 


hardware or software used for receiving and 
opening secure containers, 

said secure containers each including the 
capacity to contain a governed item, a secure 
container rule being associated with each of 
said secure containers: ; 


a protected processing environment at least in 
part protecting information contained in said 
protected processing environment from 
tampering by a user of said first apparatus, 

said protected processing environment 
including hardware or software used for 
applying said first rule and a secure container 
rule in combination to at least in part govern at 
least one aspect of access to or use of a 
governed item; and 


hardware or software used for transmission of 


Infringing. products include Office.2003 and 
included applications, and Server 2003, 
including Microsoft hosted RMS Service using 
Passport 


A device with user controls, a communications 
port, a processor and memory. For example, 
the user controls may be a keyboard and" 
mouse, the communications port may be a NIC 
card with an Ethernet port, the processor may 
be a CPU, and the memory may be a hard-drive 
or RAM. 

The first rule governs use of an IRM protected 
document (e.g., an IRM rule permitting a . 
document to be read by specified users or 
barring access to IRM-governed information 
from specified users, applications, or other 
principals). 


The RM-enabled device contains hardware or 
software for receiving and opening secure 
containers. 

The secure email has the capacity to contain an 
IRM-governed email message, with a rule 
being associated with each email. 


Protected information on the RM-enabled 
device is protected by the use of at least 
cryptographic techniques. 

The secure container rule is an IRM rule 
governing access to the IRM protected 
document (e.g., a rule permitting editing by 
specified users). 

The rule governing the email works together 
with an additional rule to determine what 
access to or use (if any) are allowed with 
respect to the IRM-governed email message 
(the document's content). For example, the 
additional rule may be received together with 
the rule in the use license, may be associated 
with a publishing license, may be associated 
with user certification, revocation lists, or 
exclusion policies, or may be received from 
any other source. 


The device includes hardware or software used 
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secure containers to other apparatuses or for 
the receipt of secure containers from other 
apparatuses; and 


for transmitting or receiving secure containers. 
For example, RM-enabled OUTLOOK is 
designed to transmit and receive encrypted 
IRM-governed emails to/from other devices: 


a second apparatus including: 


user controls, 

a communications port, 

a processor, 

a memory containing a second rule, 


A device with user controls, a communications 
port, a processor and memory. For example, 
the user controls may be a keyboard and 
mouse; the communications port may be a NIC 
card with an Ethernet port, the processor may 
be a CPU, and the memory may be a hard-drive 
or RAM. 

The second rule governs use of an ERM . 
protected document (e.g., an IRM rule * 
permitting a document to be read by specified 
users or barring access to IRM-governed 
information from specified users, applications,- 
or other principals). 


hardware or software used for receiving and 
opening secure containers, 

said secure containers each including the 
capacity to contain a governed item, a secure 
container rule being associated with each of 
said secure containers; 


The RM-enabled device contains hardware or 
software for receiving and opening secure 
containers. 

The secure email has the capacity to contain an 
IRM-governed email, item, with a rule being 
associated with each secure containers. 


a protected processing environment at least in 
part protecting information contained in said 
protected processing environment from 
tampering by a user of said apparatus, 

said protected processing environment 
including hardware or software used for 
applying said second rule and a secure 
container rule in combination to at least in part 
govern at least one aspect of access to or use 
of a governed item; 


Protected information on the RM-enabled 
device is protected by the use of at least 
cryptographic technique. 

The secure container rule is an IRM rule 
governing access to the IRM protected 
document (e.g., a rule permitting editing by 
specified users). 

The rule governing the email works together 
with an additional rule to determine what 
access to or use (if any) are allowed with 
respect to the IRM-governed item (the 
document's content). For example, the 
additional rule may be received together with 
the rule in the use license, may be associated 
with a publishing license, may be associated 
with user certification, revocation lists, or 
exclusion policies, or may be received from 
any other source. 


hardware or software used for transmission of 
secure containers to other apparatuses or for 
the receipt of secure containers from other 
apparatuses; and 


The device includes hardware or software used 
for transmitting or receiving secure containers. 
For example, RM-enabled OUTLOOK is 
designed to transmit and receive encrypted 
IRM-governed emails to/from other devices. 


an electronic intermediary, said intermediary 
including a user rights authority clearinghouse. 


The RMS Server (Microsoft hosted or 
otherwise) constructs a 'use license' specific to 
a piece content and targets- it to a specific user. 
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29. A system as in claim 28, said user rights 
authority clearinghouse operatively connected 
to make rights available to users. 


The RMS server sends use licenses to users 
through a communications port, e.g., Ethernet, 
serial, satellite, "the internet" 
These use licenses include rights. 

The clearing functionality of the RMS is 
operatively connected to the RMS server. 
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28. 


Product Infringing: Windows Media Rights 
Manager and Windows Media Player ' 


A system including: 


(a) a first apparatus including; 


Consumer's computer, as shown in WMRM 
SDK 


(1) user controls, 


Consumer's computer, as shown in WMRM 

SDK_ • 


(2) a communications port, 


Consumer's computer, as shown in WMRM 
SDK • 


(3) aprocessor, 


Consumer's computer, as shown in WMRM 
SDK 


(4) a memory containing a first rule, 


Memory is in the consumer's computer, first 
rule is a right received as part of a signed 
Hcerise (WMRM SDK, Step 9) 


(5) hardware or software used for 
receiving and opening secure 
containers, said secure containers 
each including the capacity to contain 
a governed item, a secure container 
rule being associated with each of 
said secure containers: 


Consumer's computer receives Windows 
Media file (secure container) via 
communications port (WMRM SDK, Step 3) 
and applies secure container rule or rules via 
Windows Media Player and Windows Media 
Rights Manager. 


(6) a protected processing environment at 
least in part protecting information 
contained in said protected processing 
environment from tampering by a 
user of said first apparatus, said 
protected processing environment 
including hardware or software used 
for applying said first rule and a 
secure container rule in combination 
to at least in part govern at least one 
aspect of access to or use of a 
governed item: and 


Processing environment includes Windows 
Media Rights Manager and Windows 
processes for protecting operation of Windows 
Media Rights Manager 


(7) hardware or software used for 

transmission of secure containers to 
other apparatuses or for the receipt of 
secure containers from other 
apparatuses: and 


Hardware or software employed in transmitting 
Windows Media files, including for example 
consumer's computer's communication port, 
and Windows Media Player (WMRM SDK, 
Step 3) 


V) a second apparatus including: 


2nd consumer's computer 


(1) user controls. 


2nd consumer's computer 


(2) a communications port. 


2nd consumer's computer 


(3) a processor. 


2nd consumer's computer 


(4) a memory containing a second rule, 


Memory is in the 2nd consumer's computer, 
first rule is a Right received as part of a signed 
license (WMRM SDK, Step 9) 


(5) hardware or software used foi 
receiving and opening secure 
containers, said secure containers 
each including the capacity to contain 


2nd consumer's computer receives Windows 
Media file (secure container) via 
communications port (WMRM SDK, Step 3) 
and applies secure container ruie or rules via 
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a governed item, a secure container 
rule being associated with each of 
said secure containers; 


Windows Media Player and Windows Media 
Rights Manager. 


(6) a protected processing environment at 
least in part protecting information 
contained in said protected processing 
environment from tainpering by a 
user of said apparatus said protected 
processing environment including 
hardware or software used for 
applying said second rule and a 
secure container rule in combination 
to at least in part govern at least one 
aspect of access to or use of a 
governed item; 


Processing environment includes Windows 
Media Rights Manager and Windows 
processes for protecting operation of Windows 
Media Rights Manager; processing 
environment applies multiple rules in 
combination * « 


(7) hardware or software used for 

transmission of secure containers to 
other apparatuses or for the receipt of 
secure containers from other 
apparatuses: and 


Hardware or software employed in transmitting 
Windows Media files, including for example 
2 nd consumer's computer's communication 
port and Windows Media Piayer, (WMRM 
SDK, Step 3) 


c) an electronic intermediary, said 
intermediary including a user rights 
authority clearinghouse. 


License Issuer 


9. A system as in claim 28. 


said user rights authority clearinghouse 
peratively connected to make rights available 
3 users. 


License Issuer, operatively connected to 
consumer's computer (WMRM SDK, Step 9) 
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56. 


Infringing products include Office 2003 and 
included applications, and Server 2003, 
including Microsoft hosted RMS Service using 
Passport 


\. method of securely delivering an item, 
ncluding the following steps: 


>erforming an authentication step; 


The RM-enabled application, e.g., Word, 
OUTLOOK, PowerPoint, etc., must be 
authenticated before it is allowed access to or 
use of the content. 


ssociating a digital signature with said item; 


The RM protected content is signed . 


icorporating said item into a first secure 
lectronic container, said item being at least in 
art encrypted while in said container, 

aid incorporation occurring in an apparatus 
ontaining a first protected processing 
nvironment, said protected processing 
nvironrnent at least in part protecting 
lformation contained in said protected 
rocessing environment from tampering by a 
ser of said apparatus; 


RM-protected content is packaged with rules 
and encrypted. 


Protected information on the RM enabled 
computer is protected by the use of at least 
cryptographic techniques. 


i said protected processing environment, 
ssociating a first rule with said first secure 
lectronic container, said first rule at least in 
art governing at least one aspect of access to 
r use of said item; 


The IRM-protected document (said item) has 
an associated rule or rules. 


jthenticating an intended recipient of said 
em; 


A recipient of IRM-protected content must be 
authenticated before being allowed access to or 
use of the content. 


ansmitting said first secure electronic 
)ntainer and said first^rule to said intended 
:cipient: and 


The document is sent via IRM-protected email 
as an attachment. 


sing a second protected processing 
ivironment, providing said intended recipient 
xess to at least a portion of said item, 

lid access being governed at least in part by 
Lid first rule and by a second rule present at 
lid intended recipient's site. 


The email is received at another IRM-enabled 
computer. 


The first said rule is the mle(s) associated with 
the attached document, and the second rule is 
the rulefs) received that govern the email itself. 
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126. 


Product Infringing: Windows Hardware 
Quality Labs Authentication services, 
Windows.operating Systems (such as 
Windows XP) that support the driver 
signing features, and any product using 
Driver Signing feature 


A method of providing trusted intermediary 
services including the following steps 


at a first apparatus, receiving an item from 
a second apparatus; 


Microsoft's Window Hardware Quality . 
Labs (WHQL) (first apparatus) receiving 
driver package (item) from independent 
hardware vendor (IHV) or any driver 
developer (second apparatus'). 


associating authentication information with 
said item; 


The signature information of a security 
catalog file (see next element of claim) 
names Microsoft as the publisher. 
WHQL's signature is intended to signify 
that a driver has complied with Microsoft's 
Windows compatibility and/or Secure 
Audio Path (SAP) specifications. 


ncorporating said item into a secure digital 
container; 


The hashes of the files making up the 
driver package are included in the signed 
security catalog file for the driver package. 
The catalog file makes the driver package a 
secure digital container. 


Lssociating a first rule with said secure 
ligital container, said first rule at least in 
>art governing at least one aspect of access 
o or use of said item; 


Driver developers specify rules in an INF 
file that govern the installation and/or use 
of the driver. For example, as specified in 
the INF, the installation events will vary 
based on the user's operating system 
version, which includes architecture, 
product type and suite. The INF logging 
rules and can further specify security rules 
that are evaluated when the driver is used. 

White Paper - Operating-System 
Versioning for Drivers under Windows XP 

Setup selects the {Models} section to use 
based on the following rules: 

If the INF contains [Models] sections for 
several major or minor operating system 
version numbers, Setup uses the section 
with the highest version numbers that are 
not higher than the operating system 
version on which the installation is taking 
place. 
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If the INF [Models] sections that match the 
operating system version also include 
product type decorations, product suite 
decorations, or both, then Setup selects the 
section that most closely matches the 
running operating system. 

Suppose, for example, Setup is running on 
Windows XP Professional*(which is 
operating system version 5.1), and it finds 
the following entry in a [Manufacturer] 
section: 


%FooCorp% 
NT....0x80 


=FooMfg, NT, NT..5; NT.5.5, 


In this case, Setup will look for a [Models] 
section named [FooMfg.NT.5l; Setup will 
also use the (FooMfg.NT.5) section if it is 
running on a Datacenter version of 
Windows .NET Server, because a specific 
major/minor version takes precedence over 
the product type and suite mask. 

For example, to create ah INF that is 
intended for use only on Windows XP, the 
INF file could contain the following: 

[Manufacturer] 

Too Corp." = FooMfg, NT.5.1, NT.5.2 
[FooMfg.NT.5.1] 

"Foo Device" = FooDev, *F001234 

Note the omission of the undecorated 
[FooMfg] section, as well as the omission 
of the [FooMfg.NT.5.2] section. This INF 
file would appear to be "empty" on any 
operating system other than Windows XP. 

Access Control List Rules 


XP DDK - Tightening File-Open 


Security in a Device INF File 


For Microsoft Windows 2000 and later, 
Microsoft tightened file-open security in 
the class installer INFs for certain device 
classes, including CDROM, DiskDrive, 
FDC, FloppyDisk, HDC, and * 
SCSlAdapter. 

If you are unsure whether the class installer 
for your device has tightened security on 
file opens, you should tighten security by 
using the device's INF file to assign a value 
to the DeviceCharacteristics value name 
in the registry. Do this within an add- 
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I transmitting said secure digital container 
and said first rule to a third apparatus, said 
third apparatus including a protected 
processing environment at least in part 
protecting information stored in said 
protected processing environment from 
tampering by a user of said third apparatus; 


registry-section, which is specified using 
the INF AddReg directive. 
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Microsoft, IHV, driver developer or any 
other party distributing signed driver 
packages transmitting the driver package to 
user (third apparatus). Since the driver 
package includes the INF file, it will 
include the first rule. The protected 
processing environment (PPE) is Windows 
operating system with its pertinent services 
such as Windows File Protection, signature 
and cryptographic functions, Plug and Play 
and Set-up and their related default and 
modifiable policies. The PPE checks for 
signatures on driver packages" and detects 
situations when the driver package's 
signature does not match the driver 
package. . 

Additionally, the Digital Rights Manager 
(DRM) components (kernel and client) will 
contribute to making the third apparatus a 
PPE when the SAP functionality is 
invoked. [That is, when SAP is required, an 
additional signature is checked to verify 
that the driver is SAP compliant and that it 
hasn't been tampered with.] 


15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 


said third apparatus receiving said secure 
digital container and said first rule: 


The end-user receiving the driver package. 


said third apparatus checking said 
authentication information; and 


A step in the Plug and Play/Setup driver 
installation process checks signature at 
installation. Additionally, the DRM 
component will check the DRM signature 
when invoking DRM functionality. 

White Paper - Driver Signing for Windows 


During driver installation, Windows 
compares the hashes contained in the 
driver's CAT file with the computed hash 
of the driver binaries to determine whether 
the binaries have changed since the CAT 
file was. created. If a driver fails the 
signature check or there is no CAT file, 
what happens next depends on the driver 
signing policy in effect on the user's 
system: 

If the policy is set to Ignore, the driver 
installs silently, with no message to the 
user. 

If the policy is set to Warn, a message 
warns the user the driver is unsigned, 
which means that it has not passed WHOL 
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testing and might cause problems. The 
Warn dialog, box gives an administrative 
user the option to override the warning and 
install an unsigned driver anyway. 

If the policy is set to Block, the system 
displays a message that informs the user 
that the driver. cannot be installed because - 
it is not digitally signed. 


said third apparatus performing at least one 
action on said item, said at least one action 
being governed, at least in part, by said 
first rule and by a second rule resident at 
said third apparatus prior to said receipt of 
said secure digital container and said first 
rule, said action governance occurring at 
least in part in said protected processing 
environment. 


The action would be installing and/or using 
the driver. For example, installation 
policies govern the actions (ignore, warn or 
block) taken based on whether a driver is 
signed or not and these policies (nile) are 
resident on the third apparatus. Another 
rule is the "ranking" of available drivers 
when selecting a driver to install. This 
ranking process includes whether a driver 
is signed or not. Another rule is the 
security access rules that the class installer 
that will be used to install the device has. 

In the case of DRM, the content will have 
associated rules governing its use in a SAP- 
complaint environment. These rules (the 
content license) can be resident at the third 
apparatus particularly in the case when a 
user is installing a new (SAP-compliant) 
device that will render previously acquired 
content or in the case that acquired content 
cannot be rendered until the user installs 
required drivers. 

For example, when installing: 

The XP driver ranking process and the 
modifiable default related to signature state 
of the driver act as the second rule. . 

The driver will be installed only if the first 
and second rules validate. • 

Operating-System Versioning for Drivers 
under Windows XP 


Default System Policy for Unsigned 
Drivers 

If the user installs an unsigned driver for a 
designated device class from disk or from 
another web site, Windows XP/Windows 
2000 displays a warning that the driver is 
unsigned, thus helping to preserve the 
integrity of the released system. However, 
bv default. Windows XP/Windows 2000 - 
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does not block installation of unsigned 
drivers, so vendors can get urgent hot-fixes 
to customers while waiting for WHQL to 
test the fix. 

In Windows XP, the default driver signing 
policy can be changed through the 
Hardware tab of the System applet on the . 
Control Panel. A user can change the 
policy to be more restrictive, but not less 
restrictive on a per-user basis (that is, a 
user can change Warn to Block, but not to 
Ignore); An administrator can change the 
policy to be either more restrictive or less 
restrictive for all users on the system by 
checking "Apply the setting as system 
default." 

Driver Ranking 

Under Windows XP, the driver ranking 
strategy has been modified as follows: 

If an INF file is unsigned, and if neither the 
[Models] section nor the [DDJnstall] 
. section is decorated with an NT-specific 
extension, the INF file is considered 
"suspect" and its rank is shifted into a 
higher range (that is, worse) than all 
hardware and compatible rank matches of 
INF files for which one (or both) of those 
criteria are met. 

The new ranking ranges will now be: 
0-0xFFF 

(DRJVER_HARDWAREID_RANK) : 
"trusted" hardware-ID match 
0x1000 - 0x3FFF : "trusted" compatible- 
ID match 

0x8000 - 0x8FFF : "untrusted" hardware- 
ID match 

0x9000 - OxBFFF : "untrusted" 
compatible-ID match 
OxCOOO - OxCFFF : "untrusted" 
undecorated hardware-ID match (possibly a 
Windows 9x-only driver) 
0x0000 - OxFFFF : "untrusted" 
undecorated compatible-ID match 
(possibly a Windows 9x-only driver) 


127. A method as in claim 126, in which 
said authentication information at least in 
part identifies said first app arat us and/or a 


The authentication informaiion will 
identify Microsoft, operator of the first 
apparatus. 
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126. 


Products Infringing: Microsoft Software 
that includes the Authenticode feature, 
.NET Framework SDK, Visual Studio, 
' Microsoft technology that supports a digital 
signature function (such as ActiveX), 
Windows Installer technology. 


A method of providing trusted intermediary 
services including the following steps: 


Infringement is based on use Microsoft 
ActiveX control, Cabinet file, Microsoft 
Windows Installer, Authenticode and 
Software Restriction Policy technologies. 
For example, a software publisher 
distributing a signed application that has 
licensed ActiveX controls embedded 
within it would practice this method. 


at a first apparatus, receiving an item from 
a second apparatus; 


The item is unsigned software such as an 
ActiveX control or any software packaged 
in a cabinet file or Microsoft Installer 
(.msi) file. Within the development 
environment, multiple software developers 
(working on a second apparatus) will send 
their unsigned software to a secure location 
(first apparatus) containing the entity's 
private signing key. An example entity 
would be a software publisher. 

Source: Deploying ActiveX Controls on 
the Web with the Internet Component 
Download 

The holder of the digital certificate 

Keeping your digital certificate safe is very 
important. Some firms (including 
Microsoft) do not keep their signature file 
on site; The signature is kept with the 
Certificate Authority and files are sent 
there for signing. 


issociating authentication information with- 
;aid item; 


Signing the software associates the 
software publisher's identify with the 
software. 

Source: Packaging ActiveX Controls 
Signing Cabinet Files 
A .cab file can be digitally signed like an 
ActiveX control. A digital signature 
provides accountability for software 
developers: The signature associates a 
software vendor's name with a given file. A 
signature is applied to a .cab file (or 
contro l) using the Microsoft Authenticode® 
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incorporating said item into a secure digital 
container; 


associating a first rule with said secure 
digital container, said first rule at least in 
part governing at least one aspect of access 
to or use of said item; 


technology. 

The .cab tool set assists software 
developers in applying digital signatures to 
xab files by allowing a developer to 
allocate space in the .cab file for the 
signature. 


Signing software either directly or within a 
package (cabinet or .msi file) secures it in a 
digital container. 

Alternately, the signed ActiveX control 
could be placed into a signed cabinet file. 


The first rule would be the licensing 
support code within the ActiveX control 
and/or conditional syntax statements when 
the software is within a signed .msi file. 
When the software is within a signed 
cabinet file, the first rule can be a rule 
contained in the software., as is the case 
when an ActiveX control is packaged in a 
signed cabinet file. 

First rule, in the case of ActiveX: 

When an application with a licensed 
ActiveX control is started, an instance of 
the control usually needs to be created. 
The application accomplishes this by 
making a call to CreatelnstanceLic and 
passing the license key embedded in the 
application as a parameter in the call. The 
ActiveX control performs a string 
comparison between the embedded license 
key and its own copy of the license key. If 
the keys match, an instance of the control is 
created and the application can execute 
normally. 

Source: Using ActiveX Controls to 
Automate Your Web Pages 
Run-time licensing 

Most ActiveX Controls should support 
design-time licensing and run-time 
licensing. (The exception is the control that 
is distributed free of charge.) Design-time 
licensing ensures that a developer is 
building his or her application or Web page 
with a legally purchased control; run-time 
licensing ensures that a user is running an 
application or displaying a Web page that 
contains a legally purchased control. 
Design-time licensing is verified by control 
containers such as Visual Basic. Microsoft 
Access, or Microsoft Visual InierDev®. 
Before these containers allow a developer 
to place a control on a form or Web page. 
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they first verify that the control is licensed 
by the develpper or content creator* These 
containers verify that a control is licensed 
by calling certain functions in the control: 
If the license is verified, the developer can 
add it 

Run-time licensing is also an issue for 
these containers (which are sometimes 
bundled as part of the final application); the 
containers again call functions in the 
control to validate the license that was 
embedded at design time. 

transmitting said secure digital container 
and said first rule to a third apparatus, said 
third apparatus including a protected 
processing environment at least in part 
protecting information stored in said 
protected processing environment from 
tampering by a user of said third apparatus; 

The third apparatus is a user computer qr 
an application server. The protected 
processing environment (PPE) is Windows 
operating system, Internet Explorer (IE) 
and pertinent operating IE services such as 
Windows File Protection and security, 
signature and cryptographic functions 
related to code signing and related policies. 
The PPE checks for signatures on software 
or the software packages and detects 
situations when the signature does not 
validate as an indication that tampering 
mav have occurred with the item. 

said third apparatus receiving said secure 
digital container and said first rule; 

Having the third apparatus receiving said 
secure digital container and said first rule is 
typical of networked computing 
environments. 

said third apparatus checking said 
authentication information; and 

Examine the signature information includes 
verifying that signature was creating using 
the private key that conresponds to the 
public kev of the publisher.. 

said third apparatus perfonning at least one 
action on said item, said at least one action 
being governed, at least in part, by said 
first rule and by a second rule resident at 
said third apparatus prior to said receipt of 
said secure digital container and said first 
rule, said action governance occurring at 
least in part in said protected processing 
environment. 

The action would be installation and/or use 
of the distributed software. The second 
rule can be software restriction policies 
resident on the machine, which can be 
invoKeo.ai lnsiajjauon ana/ or runiimc. 

.jnc, i rramewonc oecuniY ~ pR 

and 

White Paper - Using Software Restriction 

Policies in Windows XP and Windows 

.NET Server to Protect Against 

Unauthorized Software 

Software Restriction Polices is a policy- 
driven technology that allows 
administrators to set code-identity-based 
rules that determine whether an application 
is allowed to execute. (.NET Framework 
Security - pg 259) 
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127. A method as in claim 126, in which 
said authentication information at least in 
part identifies said first apparatus and/or a 
user of said first apparatus. 


For example, administrators can set rules 
for all Windows Installer packages coming 
from the Internet or Intranet zone. 

As part of the DLL load mechanisms, 
Software Restriction Policies is invoked 
and starts to check its most specific rules. 
Software Restriction Policies get invoked 
prior to an .exe being able to run. ' 

The four types of rules are - hash, 
certificate, path, and zone. 

Note: The hash and certificate rules relate 
directing to the signature information 
whereas, the path and zone rules do not. 


.The software publisher, user of first device, 
is identified in the authentication • 
information. 
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126. 


Product infringing: Visual Studio .NET, 
.NET Framework SDK, Authenticode, 
Products that contain the .NET CLR, 
Compact CLR or CLI. 


A method of providing trusted intermediary 
services including the following steps: 


at a first apparatus, receiving an item from 
a second apparatus; 


First apparatus is a software build or 
deployment services computer that has 
access to signing key. The item may be a 
program, graphic, media object or other 
resource, from a developer computer, or 
archive ( second 'apparatus^ 


issociating authentication information with 
>aid item; 


Associating a cryptographic hash with the 
file that will contain this item for the 
purpose of ensuring the authenticity of the 
item, along with names and attributes that 
are desired to be associated with the item 
for identification purposes. 


hcorporating said item into a secure digital 
container; 


Producing signed, strongly named 
assembly that contains this assembly and 
associated attributes. 


Lssociating a first rule with said secure 
ligital container, said first rule at least in 
>art governing at least one aspect of access 
o or use of said item; 


ransmitting said secure digital container 
nd said first rule to a third apparatus, said 
bird apparatus including a protected 
irocessing environment at least in part 
rotecting information stored in said 
rotected processing environment from 
impering by a user of said third apparatus; 


Including any security demands (such as 
members of the Microsoft .NET 
Framework SDK Public Class 
CodeAccessSecurity Attribute) as part of 
the assembly. 


The third apparatus is a user computer or 
an application server. The third 
apparatus's protected processing 
environment is Windows NT and the .NET 
CLR, CLI and/or compact CLR. 
Information is protected from tampering 
because user is not administrator, user runs 
code on server, a share on another 
computer, or over a network. Further this 
information is protected by a number of 
protection mechanisms that are included 
with the Windows NT and CLR, CLI 
and/or compact CLR distributions. 


aid third apparatus receiving said secure 
igital container and said first rule; 


Having the third apparatus receiving said 
secure digital container and said first rule is 
typical of networked computing 
environments. 


aid third apparatus checking said 
uthentication information: and 


The .NET Framework, when the assembly 
is installed into the global assembly cache 
(GAC). verifies the strong name of 
assemblies. This process includes 
verifying that signature was creating using 
the private key that corresponds to the 
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public key of the publisher. 


said third apparatus performing at least one 
action on said item, said at least one action 
being governed, at least in part, by said 
first rule and by a second rule resident at 
said third apparatus prior to said receipt of 
said secure digital container and said first 
rule, said action governance occurring at 
least in part in said protected processing 
environment. 


The action is executing code that is the 
item or using code that renders the item. 
Action is governed by security demands on 
code that calls the item or on code that calls 
code included in the .NET assembly that 
manages said item. The second rule is the 
machine, enterprise, user, and application 
configuration file resident rules. Typically 
these configuration files will be populated 
before the arrival of most new assemblies 
in a virtual distribution environment This 
action governance occurs in the protected 
processing environment of the CLR, CLI 
and/or compact CLR. • 


127, A method as in claim 126, in which 
said authentication information at least in 
part identifies said first apparatus and/or a 
jser of said first apparatus. 


The authentication information will * 
identify the .NET Assembly Class 
company name and trademark attributes 
that identify the apparatus or user of the 
first apparatus as being a member of an 
entity or a branded source (brand nameV 
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126. 


Product infringing: Visual Studio .NET, 
.NET Framework SDK, Authenticqde, 
Products that contain the .NET CLR, 
Compact CLR or CLI. 


A method of providing trusted intermediary 
services including the following steps: 


at a first apparatus, receiving an item from 
a second apparatus; 


Hie item is an unsigned .NET assembly, 
which can include, but not be limited to, a 
Web control, multi-file assembly or 
component. Within the development 
environment, multiple assembly builders 
(working on a second apparatus) will send 
their unsigned assembly to a secure ■ 
location (first apparatus) containing the 
entity's private signing key. An example 
entity would be a software publisher. 

.NET Security Framework - pg 1 30-1 


Describes this exact practice and further 
explains the "Delay Signing Assemblies" 
feature of.NET that accommodates the fact 
that "many publishers will keep the private 
key in a secure location, possibly 
embedded in specially designed 
cryptographic hardware." 

"Delay signing is a technique used by 
developers whereby the public key is added 
to the assembly name as before, granting 
the assembly its unique identity, but no 
signature is computed. Thus, no private 
key access is necessary." 


issociating authentication information with 
aid item; 


Strong naming the assembly binds the 
entity's/publisher's name into the 
assembly. The public portion of the key 
used to strongly name the assembly is 
placed in the assembly manifest. Other 
assemblies or applications can contain 
references to the strong names of strongly 
named assemblies such as in the case of 
applications that contain references to a set 
of compliant .NET core libraries. Strong 
naming compliant .NET core libraries with 
the European Computers Manufactures 
Association's (ECMA) key is a way to 
allow any publisher lo develop compliant 
.NET core libraries that can be 
authenticated by other applications. 
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.NET Security Framework - pg 1 24 
"Strong naming is a process whereby an 
assembly name can be further qualified by 
the identity of the publisher." 
.NET Security Framework - pg 1 33 
The publisher must advertise its public key 
or keys in an out-of-band fashion (such as 
documentation shipped with the product or 
on the company Web site) 
.NET Security Framework - pg 130 
The goal of the ECMA key is to allow a 
slightly more generalized strong name 
binding than usual, namely allowing 
binding to the publisher of the runtime in 
use, rather than to a fixed publisher. 


incorporating said item into a secure digital 
container; 


Signing the assembly places it in a secure 
container. 

.NET Framework Security - pg 527 
Strong named assemblies cannot be 
modified in any manner without destroying 
the strong name signature. 
Applied Microsoft .NET Framework 
Programming - pg 89 
Strongly Named Assemblies Are Tamper- 
Resistant 

When the assembly is installed into the 
GAC, the system hashes the contents of the 
file containing the manifest and compares 
the hash value with the RSA digital 
signature value embedded within the PE 
file (after unsigning it with the public key). 
If the values are identical, the file's 
contents haven't been tampered with and 
you know that you have the public key that 
corresponds to the publisher's private key. 
In addition, the system hashes the contents 
of the assembly's other files and compares 
the hash values with the hash values stored 
in the manifest file's FileDef table. If any 
of the hash values don't match, at least one 
of the assembly's files has been tampered 
with and the assembly will fail to install 
into the GAC. ; 


associating a first rule with said secure 
digital container, said first rule at least in 
)art governing at least one aspect of access 
to or use of said item; 


A .NET assembly includes imperative and 
declarative statements/rules that will 
govern its access or use. For example, 
role-based security or strong name 
demands in the assembly can be the first 
rule. 

MSDN on Role-Based Security 

Applications that implement role-based . 
security grant rights based on the role . 


1 1 

Exhibit B !j 
98 " 


associated with a principal object. The 
principal object represents the security 
context under which code is running. The 
PrincipalPermission object represents the 
identity and role that a particular principal, 
class must have to run. To implement the' 
PrincipalPermission class imperatively, 
create a new instance of the class and 
initialize it with the name and role that you 
want, users to have to access your code. 

MSDN on StrongNameldentityPermjssion 

StrongNameldentityPermission class 
defines the identity permission for strong 
names. StrongNameldentityPermission 
uses this class to confirm that calling code 
is in a particular strong-named assembly. 


transmitting said secure digital container 
and said first rule to a third apparatus, said 
third apparatus including a protected 
processing environment at least in part 
protecting information stored in said 
protected processing environment from 
tampering by a user of said third apparatus; 


The third apparatus is a user computer or 
an application server. The software 
publisher transmitting the .NET assembly 
to an end-user with a CLR. The third 
apparatus's protected processing 
environment is Windows NT and the .NET 
CLR,' CLI and/or compact CLR. 
Information is protected from tampering 
because user is not administrator, user runs 
code on server, a share on another 
computer, or over a network. Further this 
information is protected by a number of 
protection mechanisms that are included 
with the Windows NT and CLR, CLI 
and/or compact CLR distributions. 


said third apparatus receiving said secure 
digital container and said first rule: 


The end-user receiving the signed 
assembly. 


said third apparatus checking said 
authentication information; and 


The .NET Framework, when the assembly 
is installed into the global assembly cash 
(GAC), verifies the strong name of 
assemblies. This process includes 
verifying that signature was creating using 
the private key that corresponds to the 
public key of the publisher. 
A pplied Microsoft .NET Framework 
Programming - pg 89 
Strongly Named Assemblies Are Tamper- 
Resistant 
As above. 

NET Framework Security - pg 128 


The verification of any strong name 
assemblies is performed automatically 
when needed by the .NET Framework. 
Any assembly claiming a strong name but 
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failing verification will fail to install into 
the global assembly or download cache or 
will fail to load at runtime. 


said third apparatus performing at least one 
action on said item, said at least one action 
being governed, at least in part^ by said 
fast rule and by a second rule resident at 
said third apparatus prior to said receipt of 
said secure digital container and said first 
rule, said action governance occurring at 
least in part in said protected processing 
environment 


Within the CLR (protected processing 
environment), the execution of the program 
will depend upon whether the user is of the 
"role" required of the assembly or whether 
the calling assembly is from a strong- 
named assembly specified ih the "item" 
assembly (alternate first rules) and only if 
assembly complies with the local code 
access security policy (second rule), as an 
example of one of the types of rules that 
.NET Framework allows to be resident on 
the third apparatus.. 


10 
11 
12 
13 


127. A method as in claim 126, in which 
I said authentication information at least in 
j part identifies said first apparatus and/or a 

user of said first apparatus. 


The user of the first apparatus is the developer 
at the assembly developer. Strong naming 
binds the publisher's name to assembly. 


LaMacchia, Brian, etc, .NET Framework Security . Addison- Wesley, 2002 

Richter, Jeffrey, Applied Mi crosoft .NET Framework Programming . Microsoft Press, 2002 
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(b) storing said digital file in a first secure 
memory of a first device; 


(c) storing information associated with said 
digital file in a secure database stored on said 
first device, said information including at least 
one budget control and at least one copy 
control, said at least one budget control 
including a budget specifying the number of 
copies which can be made of said digital file; 
and said at least one copy control controlling' 
the copies made of said digital file; 


(d) determining whether said digital file may 
be copied and stored on a second device based 
on at least said copy control 


(e) if said copy control allows at least a portion 
of said digital file to be copied and stored on a 
second device, 


Infringing products include Windows Media 
Player and Windows Media Rights Manager 
SDK 6 


Reference is made to the Windows Media 
Rights Manager SDK Programming Reference 
("WMRM SDK"), attached hereto as Exhibit 
A. Media Player infringement analysis is set 
forth herein using the example of a music fild 
downloaded and transferred to a portable audio 
player. 

Consumer receives a Windows Media file 
(WMRM SDK. Step V f 


Windows Media file is stored in consumer's 
computer and all use of it is securely managed 
by the Secure Content Manager in Windows 
Media Player 


License is stored in the License Store (WMRM 
SDK, Step 5); license includes Rights which 
may include AHowTransfertoNonSDMI, 
AllowTransfertoSDMI, (or Allow Transfer to 
WM-D-DRM-Compliant devices or other 
types of devices), and. TransferCount- the 
number of times a piece of content may be 
transferred to the device (a transfer budget). 


Windows Media Rights Manager enforces the 
'icense restrictions 


(l)copying at least a portion of said digital 
file; 


(2)transferring at least a portion of said 
digital file to a second device 
including a memory and an audio 
and/or video outp ut; 


(3)storing said digital file in said memory 
of said second device: and 


(4)including playing said music through 
said audio output. 


Windows Media Rights Manager determines 
whether the AllowTransferToNonSDMI or 
AllowTransferToSDMI rights are present.(Or, 
Allow Transfer to WM-D-DRM-Compliant 
devices or other types of devices.) 


Transfer to the SDMI or non-SDMI portable 
device (Allow Transfer to WM-D-DRM- 
Compliant devices or other types of devices), if 
allowed bv Windows Media Rig hts Manager 


Portable device necessarily includes at least a 
memory and audio output 


Music file is transferred to the portable device 


Portable device plays the music 


2. A method. as in claim 1, further 
| comprising: 


a) at a time substantially contemporaneous 
with said transferring step, recording in said 


Counter reflecting TransferCount is 
decremented bv Windows Media 


Rights 
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I flr<;t fif*vicf* information inrlirattno that ^aiH 

transfer has occurred. 


J 3. A method as in claim 2, in which: 


1 (a) said information indicating that said 
transfer has occurred includes an encumbrance 
on said budget. 

Counter decrement reduces the allowahlp 
number of budgeted transfers 

I 4. A method as in claim *3« in which: 


1 (a) said encumbrance operates to, reduce the 
number of copies of said digital file authorized 
bv said budget. 

Counter decrement reduces the allowable 
number of budgeted transfers *' 
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Infringing products include Windows Media 
Player and. Windows Media Rights Manager 
SDK . 


:1, A method comprising: 


a) receiving a digital file; 


Consumer receives a Windows Media file 
(WMRM SDK, Step 3) 


b) storing said digital file in a first secure 
nemory of a first device; 


Windows Media file is stored in consumer's, 
computer and all use of it is securely managed 
by the Secure Content Manager in Windows 
Media Player. \ 


c) storing information associated with said 
igital file in a secure database stored on said 
irst device, said information including a first 
ontrol; 


License information is stored in the License 
Store (WMRM SDK, Step 1 0), license 
information includes Rights* License Rights 
may include AllowTransferToNonSDML, 
AllowTransferToSDMI (Allow Transfer to 
WM-D-DRM-Compliant devices or other 
types of devicesV TransferCount 


i) determining whether said digital file may 
e copied and' stored on a second device based 
n said first control, . • 


WMRM determines whether transfer rights are 
included in license (WMRM SDK, Step 5) 


(1) said determining step including 
identifying said second device and 
determining whether said first control 
allows transfer of said copied file to 
said second device, said determination 
based at least in part on the features 
present at the device to which said 
copied file is to be transferred; 


Portable Device Service Provider Module 
identifies the portable device as either SDMI- 
compliant or non-SDMI-compliant (or WM-D- 
DRM Compliant or other types of supported 
devices) and provides this information to 
Windows Media Device Manager, which 
allows the transfer based on whether the device 
identification matches the License Right 


;) if said first control allows at least a portion 
f said digital file to be copied and stored on a 
xond device, 


(1) copying at least a portion of said 
digital file; 


If Windows Media Rights Manager determines 
whether the AllowTransferToNonSDMI or 
AllowTransferToSDMI rights are present (or 
Allow Transfer to WM-D-DRM-Compliant 
devices or other types of devices), the 
following steps are performed: 


Transfer to the SDMI or non-SDMI (Allow 
Transfer to WM-D-DRM-Compliant or other) 
portable device, if allowed by Windows Media 
Rights Manager 


(2) transferring at least a portion of said 
digital file to a second device 
including a memory and an audio 
and/or video output: 


Portable device necessarily includes at least a 
memory and audio output 


(3) storing said digital file in said memory 
of said second device: and '_ 


Music file is stored in the portable device 


(4) rendering said digital file through said 
output. 


Portable device plays the music 
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Product infringing; Windows Media Player, 
Windows Media Player, Windows Media 
Rights Manager SDK .« 


15. A method comprising: 


[a) receiving a digital file; 


Consumer receives a Windows Media file 
(YWMRM SDK, Step 3) 


fb) an authentication step comprising: 


(1) accessing at least one identifier 

associated with a first device or with a 
user of said first device; and 


License includes identity of user's Windows 
Media Player: WM Players capable of playing 
protected content must be individualized. 
They contain a unique (Individualized) DRM 
client component to which protected WMA 
content licenses are bound. Content licenses 
are bound to this DRM individualization 
module as the result of a challenge sent from 
the Client to the WMLM service. The 
challenge contains information about 
Individualized DRM Client (in the form of an 
encrypted Client ID) and capabilities of the 
machine (e.g. support for Secure Audio Path 
(SAP), version of the WMRM SDK supported 
in the player. 


(2) determining whether said identifier is 
associated with a device and/or user 
authorized to store said digital file; 


Music file cannot be used unless identifier 
indicated in License matches user's Windows 
Media Player identifier (that is, the 
Individualized DRM Client to which the 
license is bound must be the same one 
supported bv the deviceV 


c) storing said digital file in a first secure 
nemory of said first device, but only if said 
levice and/or user is so authorized, but not 
iroceeding with said storing if said device 
nd/or user is not authorized; 


Music file will not be processed through 
Windows Media Player, including protected 
rendering buffers, unless the identifiers match. 
Protected WMA file can be stored oh client 
even if unauthorized but it cannot be decrypted 
and enter into the secure boundary (first secure 
memory) of the player unless appropriately 
licensed. 


d) storing information associated with said 
igital file in a secure database stored on said 
irst device, said information including at least 
ne control; 


License includes Rights and is stored in the 
License Store, Rights may include 
AllbwTransferToNonSDMI, 
AllowTransferToSDMI, (or Allow Transfer To 
WM-D-DRM-CompliantDevice or Other 
device) TransferCount 


z) determining whether said digital file may 
e copied and stored on a second device based 
n said at least one control; ; 


Windows Media Rights Manager enforces the 
icense restrictions 


[) if said at least one control allows at least a 
onion of said digital file to be copied and 
tored on a second device. 


If appropriate rights are present, the following 
sieps are performed: 


()) copying at least a portion of said 


Transfer to the SDMI or non-SDMl for WM- 
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digital file; 


(2) transferring at least a portion of said 
digital file to a second device 
including a memory and an audio 
and/or video output: 


(3) storing said digital file in said memory 
of said second device: and 


(4) rendering said digital file through said 
output. 


16. A method as in claim 15. in which: 


said digital file is received in an encrypted 
I form; 

I and further comprising: 

decrypting said digital file after said 
authentication step and before said step of 
storing said digital file in said memory of said 
first device. 


D-DRM Compliant or other) portable device, if 
allowed bv Windows Media Rights Manager 


Portable device necessarily includes at least a 
memory and audio output 


Music file is stored in the portable device 


Portable device plays the music 


Protected Windows Media File is encrypted. 
WMP will not decrypt file until license is 
processed. Licenses are bound to 
Individualization DLLs, which are bound to 
Hardware ID. Ind. DLL and Hardware ID 
must be verified as the Ids to which the license 
is. bound - this is the authentication process. : 
{Recall that this module was created based in 
part on receipt of the Client Hardware ID or 
fingerprint and the license was create based in 
part on receipt of a challenge from the client 
indicating the security properties (SAP-ready, 
SDK support, etc.) of the client). 
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19. 


Infringing products include Office 2003 and 
included applications, and Server 2003, 
including Microsoft hosted RMS Service vising 
Passport 


i method comprising: 


eceiving a digital file at a first device; 


Receiving a digital file such as a Word 
* Document, email, Excel spreadsheet, 
PowerPoint presentation, or other content at a 
recipient's device. Such content may be 
received via email, received on removable 
media, such as floppy disk, downloaded and . 
viewable by Internet Explorer, e.g. * a web page 
possibly containing graphics and/or audio data, 
etc. : 


stablishing communication between said first 
evice and a clearinghouse located at a 
)cation remote from said first device; 


If the digital file is subject to rights 
management, and the recipient tries to open the 
digital file in an IRM-enabled application, the 
IRM-enabled application contacts a remote 
RMS, i.e., clearinghouse for a use license. 


aid first device obtaining authorization 
lfonmation including a key from said 
learinghouse; 


If the recipient is authorized to access or use 
the digital file, the RMS creates a license for 
the digital file. The RMS then seals a key 
inside the license so that only the recipient 
canaccess or use the digital file. Finally, the 
RMS sends the license back to the recipient 


ud first device using said authorization 
Lformation to gain access to or make at least 
ne use of said first digital file, including 
sing said key to decrypt at least a portion of 
lid first digital file; and 


The recipient's device then uses the key in the 
license to gain access or decrypt a portion of 
the digital file. 


:ceiving a first control from said 
earinghouse at said first device; 


The license received from the RMS at the 
recipient's device contains at least one control, 
such as restricting the ability to print, forward, 
or edit. ' . 


oring said first digital file in a memory of 
tid first device; 


The digital file is stored in the memory of the 
said recipient's device, such as in RAM, on a 
hard drive, etc. 


;ing said first control to determine whether 
lid first digital file may be copied and stored 
1 a second device; 


The at least one control in the license limits 
copying the digital file. 

Such controls are set when the digital file was 
authored. For example, when the digital file is 
authored, the IRM-enabled application 
presented the author with a list of policy 
templates with different rights levels. The 
author selected an appropriate rights level 
which may for instance, allow other users in the 
svstem to onen and read the document, hut not 
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to modify it, copy text from it, or forward it. 
These rights or controls are then associated 
with the digital file. 

When an attempt is made to access the digital 
file, the RMS determines the recipient's rights 
based on the recipient's identity and the 
policies or controls associated with the digital 
file. . 

if said first control allows at least a portion of 
said first digital file to be copied and stored on 
a second device. 

If the control in the license allows copying the 
digital file to a second device, then at least a 
portion of the digital file is copied. 

copying at least a portion of said first digital 
file; 

such as by transferring or forwarding the digital 
file in an email message: 

transferring at least a portion of said first 
digital file to a second device including a 
memory and an audio and/or video output; 

A portion of the digital file is then transferred 
to a second device, such as a personal computer 
or portable device. The second device includes 
a memory and an audio and/or video output 
The memory may be a hard-drive, RAM, CD, 
DVD, or other storage. The audio and/or video 
output may be speakers arid/or a video monitor. 

storing said first digital file portion in said 
memory of said second device: and 

The digital file is stored in the second device's 
memory. 

rendering said first digital file portion through 
said output. 

The digital file is rendered through the output, 
such as played through the speakers and/or 
displayed on the video monitor. For example, a 
Word document is displayed on the screen of 
the video monitor. 
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Infringing products include Windows Media 
Player. Windows Media Rights Manager SDK 


19. A method comprising ; 


a) receiving a digital file at a first device: 


WMRM SDK: Step 3. 


b) establishing communication between said 
first device and a clearinghouse located at 
a location remote from said first device; 


WMRM SDK* Step 6. 


c) said first device obtaining authorization 
information including a key from said 
clearinghouse: 


WMRM SDK, Step 9. [License contains the 
key] . " • • 


d) said first device using said authorization 
information to gain access to or make at 
least one use of said first digital file, 
including using said key to decrypt at least 
a portion of said first digital file: and 


WMRM SDK, Step 11. 


2) receiving a first control from said 
clearinghouse at said first device: 


WMRM SDK, Steps 8-9. 


f) storing said first digital file in a memory 
of said first device: 


WMRM SDK, Step 3. 


l) using said first control to determine 
whether said first digital file may be 
copied and stored on a second device; 


At least the following WMRMRights Object 
properties meet this limitation: 
AllowTransferToNonSDMI, 
AllowTransferToSDMI (or AllowTransfer To 
WM-D-DRM-Compliant Device or other) and 
TransferCount 


i) if said first control allows at least a portion 
of said first digital file to be copied and 
stored on a second device, 


This and all subsequent claim steps occur when 
the condition specified in the WMRMRights 
Object property is met 


) copying at least a portion of said first 
digital file; 


Transfer to the SDMI or non-SDMI (or WM- 
D-DRM Compliant) portable device, if 
allowed by Windows Media Rights Manager 


) transferring at least a portion of said first 
digital file to a second device including a 
memory and an audio and/or video output: 


Portable device necessarily includes at least a 
memory and audio output 


:) storing said first digital file portion in said 
memory of said second device: and 


Music file is stored in the portable device 


) rendering said first digital file portion 
through said output. 


Portable device plays the music 


• jj 
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Infringing products include Windows Media 
Player, Windows Media Player, Windows 
Media Rights Manager SDK 


il, A method comprising : 


a) receiving a digital file at a first 
levice: 


WMRM SDK, Step 3. 


b) establishing communication 
►etween said first device and a 
learinghouse located at a location 
emote from said first device; 


WMRM SDK, Step 6. 


c).said first device obtaining . 
uthorization information from said 
learinghouse; and . • 


WMRM SDK, Step % 


j) said first device using said 
uthorization information to gain access 
> or make at least one use of said first 
igital file; 


WMRM SDK, Step 11. 


;) storing said first digital file in a 
lemorv of said first device; 


WMA file stored on client 


E) using at least a first control to 
etermine whether said first digital file 
lay be copied and stored on a second 
evice, said determination based at least 
i part on (1) identification information 
:garding said second device, and (2) 
le functional attributes of said second 
evice; 


If device is based on WM D-DRM, it has a 
certificate that is used to identify the device as 
compliant as well as the device's security 
level. The security level indicates support on 
the device for such attributes as an internal 
clock. 


») if, based at least in part on said 
lentification information, said first 
)ntrol allows at least a portion of said 
rst digital file to be copied and stored 
rc a second device. 


If License specifies that transfer of protected 
WMA file to WM-D-DRM-Compliant device 
is allowed, transfer may occur. 


rc a second oevice. 

») copying at least a portion of said 
rst digital file; 


If transfer is a licensed right as indicated in 
the license, the song is copied to the device via 
Windows Media Device Manager. 


) transferring at least a portion of said 
rst digital file to a second device 
eluding a memory and an audio 
id/or video output; 


Windows Media Device Manager transfers the 
content to the device: 


) storing said first digital file portion 
said memory of said second device; 

id 


WMA file is stored on device 


:) rendering said first digital file 
)rtion through said output. 


WMA file is rendered. 
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33. 


Infringing products include all Microsoft . 
tools that support the Microsoft ActiveX 
licensing model, Visual Studio .NET, the 
Microsoft Installer SDK, and Operating 
System products that include the Microsoft 
Installer technology. 


\ data processing arrangement comprising 
it least one storing arrangement that at 
east temporarily stores a first secure 
:ontainer comprising first protected data 
ind a first set of niles governing use of said 
irst protected data, 


The first protected data is an ActiveX 
control. 

The first alternative for the first secure 
container is the signed .msi in which the 
ActiveX developer packaged the ActiveX 
control. The first set of rules is the 
conditional syntax statements of the Signed 
.msi file; 

The second alternative for the first secure, 
container is the signed and licensed 
ActiveX control. The first set of rules is 
the license support code in the ActiveX 
control. 

A third alternative for the first container is 
a signed cabinet file containing a (signed or 
unsigned) ActiveX control with license 
support code. The first set of rules is the 
license support code in the ActiveX 
control. 


nd at least temporarily stores a second 
ecure container comprising second 
rotected data different from said first 
rotected data and a second set of rules 
overning use of said second protected 
ata; and 


The second protected data is the application 
developer's application that includes/uses 
the ActiveX control. The application 
developer's signed .msi file (second secure 
container) contains the application (second 
protected data). The second set of rules is 
the signed .msi file's conditional syntax 
statements that will be governed the 
offer/installation of the application. 


data transfer arrangement, coupled to at 
tast one storing arrangement, for . 
ansferring at least a portion of said first 
rotected data and a third set of rules 
overning use of said portion of said first 
rotected data to said second secure 
jntainer. 


Placing the licensed ActiveX control (first 
protected information) in a signed cabinet 
file (third secure container) that itself is 
included in the application's signed .msi 
file (second secure container). The third 
set of rules is the license support code in 
the ActiveX control. 


irther comprising 


means for creating and storing, in said at 
least one storing arrangement, a third 
secure container; ' 


The ability of the application developer to 
package files in signed cabinet files. 
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said data transfer arrangement farther 
comprising means for transferring said 
portion of said first protected data and 
said third set of rules to said third secure 
container, and means for incorporating 
said third secure container within said 
second secure container/ . 


The third secure container is a cabinet file 
signed by the application developer and 
including at least the licensed ActiveX 
control (first protected information. The 
licensing support code in the ActiveX 
control when its developer added licensing 
support to the ActiveX control is the third 
set of rules. 


\4. A data processing arrangement as in 
:Iaim 33 further comprising means for 
ipplying said third set of rules to govern at 
east one aspect of use of said portion of 
aid first protected data. 


Before an ActiveX control will create a 
copy of itself, the calling application has to 
pass a license key to the ActiveX control. 
The license support code in the ActiveX 
control (third rule set) evaluates the 
authenticity of the calling" application's 
request. 


5. A data processing arrangement as in 
laim 34 further comprising means for 
pplying said second set of rules to govern 
t least one aspect of use of said portion of 
aid first protected data. 


Windows Installer operating system service 
enforces the conditional syntax statements 
of the application's signed .msi file. These 
statements govern the offer/installation of 
the ActiveX control. 
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II 


Infringing products include ail Microsoft , 
tools that support the Microsoft ActiveX 
licensing model, Visual Studio .NET, the 
Microsoft Installer SDK, and Operating 
System products that include the Microsoft 
Installer technology. 


V method comprising performing the 
bllowing steps within a virtual distribution 
nvironment comprising one or more 
lectronic appliances and a first secure 
ontainer, said first secure container 
omprising (a) a first control set, and 

b) a second secure container comprising a 
econd control set and first protected 
iformation: 


The signed .msi file created by the ActiveX 
control developer is the first secure , 
container. The conditional syntax 
statement(s) of the ActiveX control 
developer's signed .msi file is/are the first 
control set. 

The first protected information is the 
ActiveX control. ' . 

The first alternative for the second secure 
container is the signed and licensed 
ActiveX control. The second control set is 
the license support code in the ActiveX 
control. 

The second alternative for the second 
secure container is a signed cabinet file 
containing the (signed or unsigned) 
ActiveX control. The second control set is 
the license support code in the ActiveX 
control. 


sing at least one control from said first 
Dntrol set or said second control set to 
overn at least one aspect of use of said 
rst protected information while said first 
rotected information is contained within 
ud first secure container; 


The ActiveX control developer's 
conditional syntax statements (first control 
set) in the ActiveX developer's signed .msi 
file govern the offer/installation of the 
ActiveX control while it is in its signed 
.msi file. 

Alternately, the license support code 
(second control set) in the ActiveX control 
governs use of the licensed ActiveX 
control. 


eating a third secure container 
>mprising a third control set for governing 
least one aspect of use of protected 
formation contained within said third 
:cure container; 


The third secure container is a signed .msi 
file. The application developer packages 
its application in a signed .msi file (third 
secure container) and includes conditional 
syntax statements (third control set) in the 
signed .msi 


corporating a first portion of said first 
otected information in said third secure 
mlainer, said first portion made up of 
>me or all of said first protected 
formation: and ._ 


Placing the ActiveX control into the 
application developer's signed .msi file 
(third secure container). 


;ine at least one control to govern at least 


The application developer's conditional 
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[ one aspect of use of said first portion of 
said first protected information while said 
first portion is contained within said third 

[ secure container. " 


syntax statement(s) in its signed .msi file 
govern the offer/installation ActiveX 
cpntrol while it is in the signed .msi file 
(third secure container). 


42. A method as in claim 41, .in which said 
first secure container further includes a 
fourth secure container comprising a fourth 
control set and second protected 
information and further comprising the 
following step: 


using at least one control from said first 
control set or said fourth control set to 
govern at least one aspect of use of said 
second protected information while said 
I second protected information is contained 
within said first secure container. 


The second protected information is a 
second; ActiveX control. 

The first alternative for the fourth secure- . 
container is the signed and licensed second 
ActiveX control. The fourth control set is 
the license support code in the ActiveX 
control. 

The second alternative for the fourth secure 
container is a signed cabinet file containing 
the (signed or unsigned) second ActiveX 
control. The fourth control set is the 
license support code in the ActiveX : 
control. 


The ActiveX control developer's 
conditional syntax statements (first control 
set) in the ActiveX developer's signed .msi 
file govern the offer/installation of the 
second ActiveX control while it is in its 
signed .msi file. 


Alternately, the license support code 
(second control set) in the ActiveX control 
governs use of the licensed ActiveX 
control. 


II 47. A method as in claim 41, in which said 
step of creating a third secure container 
includes: 


II creating said third control set by 

incorporating at least one control not found 
II in said first control set or said second 
II control set. 

The application developer's conditional 
syntax statements are not found in either 
the first control set or the second control 
set. 


|| 52. A method as in claim 4 1 in which said 
step of creating a third secure container 
occurs at a first site, and further 
comprising: 


|| copying or transferring said third secure 
container from said first site to a second 
II site located remotelv from said first site. 

The application developer at first site 
distributes its application to other sites. 


|| 53. A method as in claim 52 in which said 

first site is associated with a content 
II distributor. 

The application developer at the first site is 
the content distributor. 


II 54. A method as in claim 53 in which said 
second site is associated with a user of 

The application developer distributes the 
application to end-users. 
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content. 


55. A method as in claim 54 further 
comprising the following step: 


said user directly or indirectly initiating 
:ommunication with said first site. 


For Internet downloads, the user initiates 
the communication with the first site. 


>4. A method as in claim 54 in which said 
hird control set includes one or more 
controls at least in part governing the use 
>y said user of at least a portion of said 
Irst portion of said first protected 
nformation. 


The application developer's conditional 
syntax statements (third control set) govern 
the installation of the ActiveX control (first 
protected information). 


r 6. A method as in claim 41 in which said 
reation of said third secure container 
iirther comprises using a template which 
pecifies one or more of the controls ■ 
ontained in said third control set. 


The third secure container is the application 
developer's signed .msi file and the third 
control set is the conditional syntax 
statements in that file. 

Microsoft supplies several template .msi 
databases for use in authoring installation 
packages. The UlSample.msi is the 
template recommended in the "An 
Installation Example" on MSDN. This 
template msi files contains several default 
conditional syntax statements. At least two 
of these conditional syntax statements 
directly govern the installation by blocking 
progress until the EULA is accepted. 


8. A method as in claim 52 in which said 
reation of said third secure container 
irther comprises using a template which 
pecifies one or more of the controls 
ontained in said third control set. 


The third secure container is the application 
developer's signed .msi file and the third 
control set is the conditional syntax 
statements in that file. 

Microsoft supplies several template .msi 
databases for use in authoring installation 
packages. The UlSample.msi is the 
template recommended in the "An 
Installation Example" on MSDN. This 
template msi files contains several default 
conditional syntax statements. At least two 
of these conditional syntax statements 
directly govern the installation by blocking 
progress until the EULA is accepted. 


M 
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81. 


Infringing products include all Microsoft . 
tools that support the Microsoft ActiveX 
licensing model, Visual Studio .NET, the 
Microsoft Installer SDK, and Operating 
System products that include the Microsoft 
Installer technology. 


A data processing arrangement comprising: 


a first secure container comprising first 
protected information and a first rule set 
governing use of said first protected 
information; 


The first alternative for the first secure 
container is the ActiveX control 
developer's signed .msi file containing a 
HcensetfActiveX control (the first. . 
protected information). The conditional 
syntax statements of the signed .msi file are 
the first rule set. . 

The second alternative for the first secure 
container is the signed cabinet file 
containing the ActiveX control. The 
license support code in the ActiveX control 
is the first rule set 

The third alternative for the first secure 
container is the licensed and signed 
ActiveX control governed by license 
support code in the ActiveX control. 


a second secure container comprising a 
second rule set; 


The second secure container is the signed 
msi file which the application developer 
package its application. The second rule 
set is the conditional syntax statements of 
the application developer's signed .msi file. 


means for creating and storing a third 
I secure container, and 


The third container is a signed cabinet file 
containing at least the ActiveX control. 


means for copying or transferring at least a 
portion of said first protected information 
and a third rule set governing use of said 
portion of said first protected information 
to said second secure container, said means 
for copying or transferring comprising: 


Putting the licensed ActiveX control (first 
protected information) in a signed cabinet 
file (third secure container). The licensing 
support code in the ActiveX control is third 
rule set. 


means for incorporating said third 
secure container within said second 
secure container. 


Packaging the signed cabinet file in the 
signed .msi file. 


82, A data processing arrangement as in 
claim 81 further comprising: 


means for applying at least one rule from 
said third rule set to at least in part govern 
at least one factor related . to use of said 
portion of said first proiected information. 


The third rule set ensures the user is 
licensed. 


83. A data processing arrangement as in 
claim 82 further comprising: 


293482.02 
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means for applying at least one rule from 
said second rule set to at least in part 
govern at least one factor related to use of 
said portion of said first protected 
information. \ 


The second rule set governs the 
offer/installation of first protected 
information. 


Exhibit B 
116 


ii 

:l 


1 

2 
3 
. 4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 


INTERTRUST TECHNOLOGIES CORP. v. MICROSOFT CORP. 
INTERTRUST INFRINGEMENT CHART 
FOR U.S. PATENT NO. 5,915,019 


85, 


Infringing products include all Microsoft 
tools that support the Microsoft ActiveX . 
licensing model, Visual Studio .NET, the 
Microsoft Installer SDK, and Operating . 
System products that include the Microsoft 
Installer technology. 


A method comprising the following steps: 


creating a first secure container comprising 
a first rule set and first protected 
information; 


The first protected information is the 
ActiveX control. 

The first alternative for the first secure 
container is the signed and licensed 
ActiveX control. The first rale set is the 
license support code in the ActiveX* ' 
control. 

The second alternative for the first secure 
container is an (signed or unsigned) 
ActiveX control with license support 
contained within a signed cabinet file. The 
first rule set is the ActiveX license support 
code. 


storing said first secure container in a first 
Tiemorv: 


The first secure container is stored at the 
ActiveX control developer's location. 


:reating a second secure container 
comprising a second rule set; . 


The second secure container is the 
application developer's signed .msi file. 
The conditional syntax statements of the 
signed .msi file are the second rule set. 


;toring said second secure container in a 
second memory: 


The second secure container is stored at the 
application developer's location. 


;opying or transferring at least a first 
portion of said first protected information 
o said second secure container, said 
:opving or transferring step comprising: 


The ActiveX control developer packages 
the control in a signed .msi file for 
distribution to the application developer's 
site. ' : 


seating a third secure container 
comprising a third rule set; 


The third secure container is the ActiveX 
control developer's signed .msi file 
containing a licensed ActiveX control. The 
conditional syntax statements of the signed 
.msi file are the third rule set. 


copying said first portion of said 
first protected information; 


transferring said copied first portion 
of said first protected information to 
said third secure container: and 


In preparation for using a msi authoring 
tool, such as Microsoft's Orca, copying the 
ActiveX control to a package staging area. 


Using msi authoring tool to import the 
control into the signed .msi file. 


copying or transferring said copied 
first portion of said first protected 
information. from said third secure 
container to said second secure 
container. ' 


The application developer installs the 
ActiveX control, which involves removing 
it from the ActiveX developer's signed 
; msi file and installing it into its, 
environment. Subsequently, the- 
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application developer places the ActiveX 
control into .its signed .msi file when it is 
packaging its application. 


87. A method as in claim 85 in which said 
copied first portion of said first protected 
information consists of-tfce entirety of said 
first protected information. \ ' 


The entire ActiveX control is copied. 


89. A method as in claim 85 in which 


said first memory is located at a first site, 


The fust memory is located at the ActiveX 
control developer's site. 


said second memory is located at a second 
site remote from said first site, and 


The second memory is located at the 
application developers site. 


said step of copying or transferring said 
First portion of said first protected 
nformation to said second secure container 
urther comprises copying or transferring 
;aid third secure container from said first 
;ite to said second site. 


The ActiveX control developer's signed 
r msi file is transferred from its site to the 
site of the application developer. 
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85. (alternate infringing scenario) 


A method comprising the following steps: 


Infringing products include all Microsoft 
tools that support the Microsoft ActiveX 
licensing model, Visual Studio .NET, the. 
Microsoft Installer SDK, and Operating . 
System products that include the Microsoft 
Installer technology* 


creating a first secure container comprising 
a first rule set and first protected 
information; 


The first protected information is the 
ActiveX control. 

The first alternative for the first secure 
container is the signed and licensed 
ActiveX control The first rule' set is the 
license support code in the ActiveX' 1 
control. 

The second alternative for the first secure 
container is a (signed or unsigned) ActiveX 
control with license support contained 
within a signed cabinet file. The first rule 
set would remain the ActiveX license 
support code. 

The third alternative for the first secure 
container is a signed msi file in which the 
ActiveX control developer packaged its 
ActiveX control. The first rule set is the 
conditional syntax statement(s) of the 
signed msi file. 


storing said first secure container in a first 
memory: - 


The first secure container is stored at the 
ActiveX control developer's location. 


:reating a second secure container 
:omprising a second rule set; 


The second secure container is the 
application developer's signed .msi file. 
The conditional syntax statements of the 
signed .msi file are the second rule set. 


storing said second secure container in a 
second memory: 


The second secure container is stored at the 
a pplication developer's location. 


copying or transferring at least a first 
portion of said first protected information 
o said second secure container, said 
copying or transferring step comprising: 


The ActiveX control is placed in a cabinet 
file signed by the application developer and 
the signed cabinet file is placed in a .msi 
file signed bv the application developer. 


seating a third secure container 
comprising a third rule set; 


The third secure container is signed cabinet 
file in which the application developer 
placed licensed ActiveX. The third rule set 
is the license support code in the ActiveX 
control. 


copying said first portion of said 
first protected information: 


Copying ActiveX control. 


transferring said copied first portion 
of said first protected information to 


Transferring ActiveX control to signed 
cabinet file. *_ 
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said third secure container, and 


copying or transferring said copied 
first portion of said first protected 
information from said third secure 
container to said second secure 
container. 


The application developer places the signed 
cabinet file into its signed .msi file when it 
is packaging its application. 


87. A method as in claim 85 in which said 
copied first portion of said first protected 
information consists of the entirety of said 
first protected information. 


The entire ActiveX control is copied. 


93. A method as in claim 85 in which 


said step of copying transferring said 
copied first portion of said first protected 
information from said third secure 
container to said second secure container 
further comprises storing said third secure 
container in said second secure container. 


The ActiveX control is placed in a cabinet 
file signed by the application developer arid 
the signed cabinet file is placed in a .msi 
file signed by the application developer. 


it 
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Infringing products include the .NET 
Framework SDK, Microsoft Visual Studio 
!NEt, the Microsoft Installer SDK, and- • 
products that include the Microsoft .NET . 
CLR, and the Microsoft Installer . 
technology. 


\ method of operating on a first secure 
container arrangement having a first set of 
controls associated therewith, said first 
>ecure container arrangement at least in 
)art comprising a first protected content 
lie, said method comprising the following 
;teps performed within a virtual 
iistribution environment including at least 
>ne electronic appliance: 


The first protected content is a signed and 
licensed .NET component used by.the * 
.NET assembly. The .NET assembly is 
distributed with a signed and governed .msi 
file. . The second protected content is 
another signed and licensed .NET 
component that is used by the .NET 
assembly. 


ising at least one control associated with 
;aid first secure container arrangement for 
governing, at least in part, at least one 
ispect of use of said first protected content 
ile while said first protected content file is 
contained in said first secure container 
irrangement; 


The first protected content is signed and 
licensed .NET component (first secure 
container) contained within the .NET 
assembly. The one control is a declarative 
statement(s) within the assembly's header. 


reating a second secure container 
rrangement having a second set of 
ontrols associated therewith, said second 
et of controls governing, at least in part, at 
sast one aspect of use of any protected 
ontent file contained within said second 
ecure container arrangement; 


The protected content is the same as the 
first protected content plus the additional 
implementation information included in the 
signed .msi file. The second secure 
container is the signed .msi file created for 
the .NET assembly. The signed .msi file's 
conditional syntax statements are the 
second set of controls that control the 
offer/installation of the .NET assembly. 


ransferring at least a portion of said first 
rotected content file to said second secure 
ontainer arrangement, said portion made 
p of at least some of said first protected 
ontent file; and 


The entire .NET assembly is included in 
the signed .msi file. 

Packaging the .NET assembly in the signed 
.msi file involves the following process 
steps. In preparation for using a msi 
authoring tool, such as Microsoft's Orca, 
copying the .NET component to a package 
staging area. Using msi authoring tool to 
import the .NET component into the signed 
.msi file. __ 


sing at least one rule to govern at least one 
spect of use of said first protected content 
le portion while said portion is contained 
'ithin said second secure container 
rrangement: ; 


The conditional syntax statement(s) of the 
signed .msi file (second secure container) 
control(s) the offer/installation of the .NET 
assembly. 


i which 


lid first secure container arrangement 
emprises a third secure container 


The first alternative for the third secure 
container is a licensed and signed .NET 


i 
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component governed by the set of 
declarative statements comprising the 
LicenseProviderAttribute (third set of 
controls). 

The second alternative for the third secure* 
container is a .NET component whose hash 
is included in the header of the .NET 
assembly. The set of declarative • 
statements comprising the 
LicenseProviderAttribute is the third set of 
controls. ; . 


arrangement comprising a third set of 
controls and said first protected content 
file, and 


said first secure container arrangement 
further comprises a fourth secure container 
arrangement comprising a fourth set of 
controls and a second protected content 
file. 


The first alternative for the fourth secure 
container is another licensed and signed 
.NET component governed by the set of 
declarative statements comprising the 
LicenseProviderAttribute (fourth set of 
controls). - 

The second alternative for the fourth secure 
container is the container created when the 
hash of the .NET component is included in 
the header information of the .NET 
assembly. The set of declarative 
statements comprising the 
LicenseProviderAttribute is the fourth set 
of controls. 
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33. 


A data processing arrangement comprising 
at least one storing arrangement that at 
least temporarily stores a first secure 
container comprising first protected data 
and a first set of rules governing use of said 
first protected data, 


and at least temporarily stores a second 
secure container comprising second 
protected data different from said first 
protected data and a second set of rules 
joveming use of said second protected 
data; and 


Infringing products include the .NET 
Framework SDK, Microsoft Visual Studio 
.NET, the Microsoft Installer SDK, and 
products that include the Microsoft .NET 
CLR, and the Microsoft Installer 
technology. 


data transfer arrangement, coupled to at 
east one storing arrangements for 


The first protected information is the .NET 
component. 

The first alternate for the first secure 
container is the signed .msi file in which 
the .NET component developer packaged 
its .NET component. The first set of rules 
is the conditional syntax statements of the 
signed .msi file. 

The second alternative for the first secure 
container is a licensed and signed .NET 
component governed by the set of 
declarative statements comprising the 
LicenseProviderAttribute of the :NET 
component (first set of controls). 

The third alternative for the first container 
is a signed cabinet file containing a (signed 
or unsigned) .NET component with license 
support. The first set of controls is the set 
of declarative statements comprising the 
LicenseProviderAttribute of the .NET 
component. 

The second protected data is the .NET 
assembly developer's assembly that 
includes/uses the .NET component. 

The first alternative for the second secure 
container is a signed .msi file in which the 
.NET assembly developer packaged its 
multi-file assembly (second protected 
data). The second set of rules is the 
conditional syntax statements of the signed 
msi file that governs the offer/installation 
of the .NET assembly. 

The second alternative for the second 
secure container is a signed .NET 
assembly. The second set of rules is the 
declarative rules within the assembly's 
header. 


The third secure container is a signed .NET 
assembly governed by declarative rules in 
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transferring at least a portion of said first 
protected data and a third set of rules 
governing use of said portion of said first 
protected data to said second secure 
container, 


its header (third set of rules). An 
alternative third role set is the set of 
declarative statements comprising the 
LicenseProvider Attribute. The .NET 
assembly includes the .NET component. . 
The secure .NET assembly is included in a 
signed .msi file (second secure container). 

An alternative third secure container is the 
container created by hashing the .NET 
component and including the hash in the 
header information of a .NET assembly. 
The .NET component is included in the 
signed and governed .NET assembly 
(second secure container). The third set of 
rules is the set of declarative statements 
comprising the LicenseProviderAttribute. 

An alternative third secure container is a 
signed cabinet file containing the .NET 
component and which is destined for a 
signed .msi file (second secure container). 
The third set of rules is the set of 
declarative statements comprising the 
LicenseProviderAttribute. 


further comprising 


means for creating and storing, in said at 
least one storing arrangement, a third 
secure container; 


The first alternative for the third secure 
container is a signed .NET assembly. In 
this case, the second secure container is the 
signed .msi file. 

The second alternative for the third 
container is the container created by 
including a hash of the .NET component in 
the header information of a .NET assembly. 
In this case, the second secure container is 
either the signed .msi file or the signed 
.NET assembly. 

The third alternative for the third container 
is a cabinet file signed by the .NET 
assembly developer containing the .NET 
assembly and/or the .NET component. In 
this case the signed .msi file is the second 
secure container. 


said data transfer arrangement further 
comprising means for transferring said 
portion of said first protected data and 
said third set of rules to said third secure 
container, and means for incorporating 
said third secure container within said 
second secure coniainer. 


The first alternative for the third secure 
container is the signed .NET assembly, 
which' includes and/or uses the licensed 
.NET component (first protected 
information). The third set of rules is a 
declarative rule within the .NET 
assembly's header. The .NET assembly is 
placed in a signed .msi file (second secure 
container). 
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The second alternative for the third secure 
container is .the container that results when 
the hash of the .NET component is added 
to the .NET assembly header information. 
The third set of rules is the set of 
declarative statements comprising the 
LicenseProviderAttiribute added to the 
assembly. 

The third alternative for the third secure 
container is a cabinet file signed by the 
.NET assembly developer containing the 
.NET assembly and/or the .NET 
component TTie third set of rules is a 
declarative rule(s) within the .NET 
assembly's header and/or the set of 
declarative statements comprising the 
LicenseProviderAttribute added to the 
assembly 


4. A data processing arrangement as in 
laim 33 further comprising means for 
pplying said third set of rules to govern at 
iast one aspect of use of said portion of . 
aid first protected data. 


When the third rule set is the declarative 
statement(s) of the assembly header, the 
runtime CLR enforces the statements. 

When the third set of rules is the set of 
declarative statements comprising the 
LicenseProviderAttribute added to the 
assembly, the license support code in the 
.NET component evaluates the authenticity 
of the calling assembly's request. 


5. A data processing arrangement as in 
laim 34 further comprising means for 
pplying said second set of rules to govern 
t least one aspect of use of said portion of 
lid first protected data. 


When the second set of rules is the 
conditional syntax statements of the signed 
.msi file, the Windows Installer operating 
system service enforces the conditional 
syntax statements of.NET assembly's 
signed .msi file, which govern the 
offer/installation of the .NET component 

When the second set of rules is the 
declarative statements) within the 
assembly's header, the runtime CLR 
enforces the statements. 
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Infringing products include the .NET 
Framework SDK, Microsoft Visual Studio 
.NET, the Microsoft Installer SDK, and 
products that include the Microsoft .NET 
CLRi and the Microsoft Installer * 
technology. 


K method comprising performing the 
bllowing steps within a virtual distribution 
invironment comprising one or more 
:Iectronic appliances arid a first secure 
container, said first secure container 
comprising (a) a first control set, and 

b) a second secure container comprising a 
;econd control set and first protected 
nformation: 


The Signed jnsi file created by the .NET 
component developer is the first secure 
container. The first conditional syntax ' 
statement(s) of the .NET component 
-developer's signed .msi file is/are the first 
control set. 

The first protected information is the .NET 
component. 

The first alternative for the second secure 
container is the signed and licensed .NET 
component. The second control set is the 
set of declarative statements comprising the 
LicenseProviderAttribute. 

The second alternative for the second 
secure container is a signed cabinet file. 
The second control set remains the set of 
declarative statements comprising the 
LicenseProviderAttribute. 


ising at least one control from said first 
ontrol set or said second control set to 
overn at least one aspect of use of said 
irst protected information while said first 
irotected information is contained within 
aid first secure container; 


The .NET component developer's 
conditional syntax statements (first control 
set) in its signed .msi file governs the 
offer/installation of the .NET component 
while it is in the signed .msi file. 

Alternately, the set of declarative 
statements comprising the 
LicenseProviderAttribute (second control 
set) of the licensed .NET component 
governs use of the .NET component. 


reating a third secure container 
omprising a third control set for governing 
t least one aspect of use of protected 
^formation contained within said third 
ecure container; 


The first alternative for the third secure 
container is a signed .NET assembly, the 
protected information is the .NET 
component and the third control set is the 
declarative statement(s) within the .NET 
assembly's header. 

The second alternative for the third secure 
container is a signed .msi file in which the 
.NET assembly developer packages its 
.NET assembly and the third control set is 
the conditional syntax statement(s) in the 
signed .msi file. - 
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incorporating a first portion of said first 
protected information in said third secure 
container, said first portion made up of 
some or all of said first protected 
information; and 

In The first alternative, placing the .NET 
component into the signed .NET assembly. 

In the second alternative, placing the .NET 
component into the. Net assembly 
developer's signed msi file. 

using at least one control to govern at least 
one aspect of use of said first portion of 
said first protected information while said 
first portion is contained within said third 
secure container. 

In the first alternative, the .NET assembly 
developer's declarative statement(s) within 
the .NET assembly's header govern(s) the 
use of the .NET component while- it is in 
the signed .NET assembly. 

In the second alternative, the conditional 
syntax statements of the .NET assembly 
developer's signed .msi file govern the 
offer/installation of the .NET component 
while it is in the siened .msi file. 


42. A method as in claim 41, in which said 
first secure container further includes a 
fourth secure container comprising a fourth 
control set and second protected 
information and further comprising the 
following step: 

The second protected information is/a 
second .NET component. 

The first alternative for the fourth secure 
container is the signed and licensed second 
.NET component. The fourth control set is 
the set of declarative statements comprising 
the LicenseProviderAttribute of the second 
.NET component. 

The second alternative for the fourth secure 
container is a second signed cabinet file. 
The fourth control set is the set of 
declarative statements comprising the 
LicenseProviderAttribute. 

using at least one control from said first 
control set or said fourth control set to 
govern at least one aspect of use of said 
second protected information while said 
second protected information is contained 
within said first secure container. 

The .NET component developer's 
conditional syntax statements (first .control 
set) in its signed .msi file governs the 
offer/installation of the second .NET * 
component while it is in the signed .msi 
file. 

Alternately, the set of declarative 
statements comprising the 
LicenseProviderAttribute (fourth control 
set) of the licensed second .NET 
component governs use of the second .NET 
comoonent. 


47. A method as in claim 41, in which said 
step of creating a third secure container 
includes: 


creating said third control set by 
incorporating at least one control not found 
in said first control set or said second 
control set. 

The .NET assembly developer's declarative 
statements (first alternative for third control 
set) and/or the developer's conditional 
syntax statements (second alternative for 
the third control seO are not found in either 
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the first control set or the second control 
set. . 


4 

52. A method as in claim 41 in which said 
step of creating a third secure container 
occurs at a first site, ^nd further 
comprising: * " . 


5 
6 

copying or transferring said third.secure 
container from said first site to a second 
site located remotely from said first site. 

The .NET assembly developer at first site - 
distributes its assembly to other sites. 



7 
8 

53. A method as in claim 52 in which said 
first site is associated with a content 
distributor. 

The .NET assembly developer's business 
module is used to create and distribute its 
assembly. . 


9 
10 

54. A method as in claim 53 in which said 
second site is associated with a user of 
content. 

The .NET assembly developer distributes 
the assembly to end-users. 


11 

55. A method as in claim 54 further 
comprising the following step: 


12 

said user directly or indirectly initiating 
communication with said first site. 

For Internet downloads, the user initiates 
the communication with the first site. 

13 


14 

1 3 

16 

64. A method as in claim 54 in which said 
third control set includes one or more 
controls at least in part governing the use 
by said user of at least a portion of said 
first portion of said first protected 
information. 

When the third control set is the .NET 
assembly developer's declarative 
statements) within the .NET assembly's 
header, it governs the user's use of the 
.NET component (first protected 
information). 

17 . 
18 
19 
20 


When the third control set is the .NET 
assembly developer's conditional syntax 
statements of the .NET assembly 
developer's signed .msi file, it governs the 
user's offer acceptance/installation of the 
.NET component (first protected 
informationV 
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76. A method as in claim 41 in which said 
creation of said third secure container 
further comprises using a template which 
specifies one or more of the controls 
contained in said third control set 

When the third secure container is the 
.NET assembly developer's signed .msi file 
and the third control set is the conditional 
syntax statements in that file. 

Microsoft supplies several template .msi 
databases for use in authoring installation 
packages. The UlSample.msi is the 
template recommended in the "An 
Installation Example" on MSDN. This 
template msi files contains several default 
conditional syntax statements. At least two 
of these conditional syntax statements 
directly govern the installation by blocking 
orogress until the EULA is accepted. 
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78. A method as in claim 52 in which said 
creation of said third secure container 
further comprises using a template which 
specifies one or more of the controls 
contained in said third control set. 


When the third secure container is the 
.NET assembly developer's signed .msi file 
and the third control set is the conditional . 
syntax statements in that file. 

Microsoft supplies several template .msi 
databases for use in authoring installation 
packages. The IjISample.msi is the 
template recommended in the "An- 
Installation Example" on MSDN. This 
template msi files contains several default 
conditional syntax statements. At least two 
of these conditional syntax statements " 
directly govern the installation by blocking 
progress until the EULA is accepted. 
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Jl. 


\ data processing arrangement comprising: 


Infringing products include the .NET 
Framework SDK, Microsoft Visual Studio. 
.NET, the Microsoft Installer SDK, and 
products that include the Microsoft .NET 
CLR, and the Microsoft Installer 
technology. 


i first secure container comprising first 
)rotected information and a first rule set 
governing use of said first protected 
nformation; 


The first protected information is the .NET 
component. 

The first alternative for the first secure 
container is the signed .msi file in which 
the .NET component developer packaged 
its assembly. The first rule set is the 
conditional syntax statements written by 
the .NET component developer and placed 
into the signed .msi file. 

The second alternative for the first secure 
container is the signed cabinet file 
containing the (signed or unsigned) .NET 
component. The set of declarative 
statements comprising the 
LicenseProviderAttribute when its 
developer added licensing support to the 
assembly is the first rule set. 

The third alternative for the first secure 
container is the licensed and signed .NET 
component governed by the set of 
declarative statements comprising the 
LicenseProviderAttribute (first rule set) 
added bv the .NET component developer. 


second secure container comprising a 
econd rule set; 


The first alternative for the second secure 
container is the signed .msi file in which 
the .NET assembly developer packaged its 
.NET assembly. The second rule set is the 
conditional syntax statements written by 
the .NET assembly developer and placed 
into the signed .msi file. 

The second alternative for the second 
secure container is the signed .NET 
assembly. The second rule set is the 
declarative statements in the .NET 
assembly's header. : 


leans for creating and storing a third 
ecuie container; and 


When the second secure container is the 
signed msi file, the third secure container is 
the signed .NET assembly . 

When the second secure container is the 
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signed .NET assembly, the third secure 
container a .NET component secured by 
placing it in a signed cabinet file or by 
including its hash in the header of the 
assemblv. 

means for copying ortransferring at least a 
portion of said first protected; information 
and a third rule set governing :u£e of said 
portion of said first protected information 
to said second secure container, said means 
for copying or transferring comprising: 

When the second secure container is the 
signed msi file and the third secure . 
container is the signed .NET assembly, the 
third rule set is the set of declarative . 
statements within the assembly's header. 

When. the second secure container is the 
signed .NET assembly, the third rule set is 
the set of declarative statements comprising 
the LicenseProviderAttribute (third rule 
set) added to the .NET Component by its 
developer. 

meansfor incorporating said third 
secure container within said second 
secure container. 

When the second secure container is the 
signed msi file and the third secure , 
container is the signed .NET assembly, the 
assembly is placed in the signed .msi file. 

When the second secure container is the 
signed .NET assembly and the third secure 
container is a .NET component contained 
in a signed cabinet file or a .NET 
component whose hash is included in the 
header of the assembly, the third secure 
container is incorporated within the .NET 
assemblv. 


82. A data processing arrangement a$ in 
claim 81 further comprising: 


means for applying at least one rule from 
said third rule set to at least in part govern 
at least one factor related to use of said 
portion of said first protected information. 

When the third rule set is declarative 
statements within the assembly's header, it 
governs the use of the .NET assembly 
which includes the first protected 
information. 

When the third rule set is the set of 
declarative statements comprising the 
LicenseProviderAttribute added by the 
.NET component by its developer, it 
ensures the user is licensed. 


83. A data processing arrangement as in 
claim 82 further comprising: 


means for applying at least one rule from 
said second rule set to at least in part 
govern at least one factor related to use of 
said portion of said first protected 
information. 

When the second rule set is the conditional 
syntax statements written by the .NET 
assembly developer and placed into the 
signed .msi file, it governs the 
offer/installation of the .NET component. 

When the second rule set is the declarative ; 
statements in the .NET assembly's header. 
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it governs the use of the .NET assembly, 
which includes the first protected 
information. 
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85. A method comprising the following 
steps: 


Infringing products include the .NET 
Framework SDK, Microsoft Visual Studio 
;NET, the Microsoft Installer SDK, and 
products that include the Microsoft .NET 
CLR, and the Microsoft Installer 
technology. 


creating a first secure container comprising 
a first rule set and first protected 
information; 


The first protected information is the .NET 
component. , 

The' first secure container is a signed .NET 
component (first protected information) - 
governed by the set of declarative 
statements comprising the 
LicenseProviderAttribute (first rule set). 

The second alternative for the first secure 
container is a cabinet file signed by the 
.NET component developer containing a 
(signed or unsigned) .NET component with 
license support. The first rule set is the set 
of declarative statements comprising the 
LicenseProviderAttribute. 


>toring said first secure container in a first 
nemorv: 


The first secure container is stored at the 
.NET component developer's location. 


creating a second secure container 
comprising a second rule set; 


The first alternative for the second secure 
container is a signed .NET assembly and 
the second rule set is declarative 
statement(s) within the assembly's header. 

The second alternative for the second 
secure container is the signed .msi file in 
which the .NET assembly developer 
packages its (signed or unsigned) 
assembly. The second rule set is the 
conditional syntax statement(s) written by 
the .NET assembly developer and placed 
into the signed .msi file. 


toring said second secure container in a 
econd memory: 


The second secure container is stored at the 
.NET assembly developer's location. 


opying or transferring at least a first 
lortion of said first protected information 
3 said second secure container, said 
opying or transferring step comprising: 


The .NET component developer packages 
its module in a signed .msi file for 
distribution lo the .NET assembly 
developer's site. 


reating a third secure container 
omprising a third rule set; 


The third secure container is the signed 
.msi file in which the ;NET component 
developer packaged its .NET component. 
The third control set is the conditional 
syntax statements written by the .NET 
component developer and placed into the 
signed .msi file. 


copying said first portion of said 


In preparation for using a msi authoring 
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first protected information; 


tod!, such as Microsoft's Orca, copying the 
.NET component to a package staging area. 


transferring said copied first portion 
of said first protected information to 
said third secure container: and 


Using the msi authoring tool to import the 
.NET component into the signed .msi file. 


The .NET assembly developer installs the 
.NET component, which involves 
removing it from the .NET component * 
developer's signed .msi file and installing it 
into its environment. Subsequently, the 
.NET assembly developer places the .NET 
component into its .NET assembly and/or 
signed .msi file when it is packaging its : 
.NET assembly. 


copying or transferring said copied 
first portion of said first protected 
information from said third secure 
container to said second secure 
container. 


J7. A method as in claim 85 in which said 
:opied first portion of said first protected 
nformation consists of the entirety of said 
Irst protected information. 


The entire .NET component is copied. 


?9. A method as in claim 85 in which 


;aid first memory is located at a first site, 


The first memory is located at the .NET 
component developer's site. 


;aid second memory is located at a second 
;ite remote from said first site, and 


The second memory is located at the .NET 
assembly developer's site. 


;aid step of copying or transferring said 
irst portion of said first protected 
nformation to said second secure container 
iuther comprises copying or transferring 
aid third secure container from said first 
ite to said second site. . 


The .NET component developer's signed 
.msi file is transferred from its site to the 
site of the .NET assembly developer. 


>4. A method as in claim 85 further 
omprising: 


reating a fourth rule set. 


When the second secure container is not a 
signed .NET assembly, the fourth rule set is 
declarative statements within the 
assembly's header. 

When the second secure container is not 
the signed .msi file in which the .NET 
assembly developer packages its (signed or 
unsigned) assembly, the fourth rule set is 
the conditional syntax statements written 
by the .NET assembly developer and 
placed into the signed .msi file. 
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85 (alternate infring in g scenario) 


A method cpmprising the following steps: 


Infringing products include the .NET 
Framework SDK, Microsoft Visual Studio 
.NET, the Microsoft Installer SDK, and 
products that include the Microsoft .NET 
CLR, and the Microsoft Installer 
technology. 


creating a first secure container comprising 
a first rule set and first protected 
information; 


storing said first secure container in a first 
memory; 


creating a second secure container 
comprising a second rule set; 


The first protected information is the .NET 
component. 

The first alternative for the first secure 
container is the signed and licensed .NET 
component. The first rule set is the set of 
declarative statements comprising the 
LicenseProviderAttribute in the .NET 
component. 

The second alternative for the first secure 
container is a (signed or unsigned) .NET 
component with license support contained 
within a cabinet file signed by the .NET 
component developer. The first rule set is 
the set of declarative statements comprising 
the LicenseProviderAttribute in the .NET 
component 

The third alternative for the first secure 
container is the signed .msi file in which 
the .NET component developer packaged 
its assembly. The first rule set is the 
conditional syntax statements written by 
the .NET component developer and placed 
into the signed .msi file. 


The first secure container is stored at the 
.NET component developer's location. 


The first alternative for the second secure 
container is a signed .NET assembly and 
the second rule set is declarative 
statement(s) within the assembly's header. 

The second alternative for the second 
secure container is the signed .msi file in 
which the .NET assembly developer 
packages its (signed or unsigned) 
assembly. The second rule set is the 
conditional syntax statement(s) written by 
the .NET assembly developer and placed 
into the signed .msi file. 


storing said second secure container in a 
second memory: 


The second secure container is stored at the 
.NET assembly developer's location. 


copying or transferring at least a first 


The .NET assembly developer places the 
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portion of said first protected information 
to said second secure container, said 
copying or transferring step comprising: 

.NET component into the third secure 
container, which is either a signed cabinet 
file or a signed .NET assembly. 

creating a third secure container 
comprising a third rule set; 

When the second secure container is the 
signed .msi file, the third secure container, 
is the signed .NET assembly. The third 
rule set is the declarative statements) in 
the .NET assembly's header. . , 

When the second secure container is either 
a .NET assembly or the signed .msi file, the 
third secure container is a signed cabinet 
file in which the .NET assembly developer 
placed licensed .NET component. The 
third rule set is the set of declarative 
statements comprising the 
LicenseProviderAttribute in" the .NET 
component. 

copying said first portion of said 
first protected information; 

Copying the .NET component to either the 
.NET assembly or to the signed cabinet 
file. 

transferring said copied first portion 
of said first protected information to 
said third secure container: and 

Transferring the .NET component to either 
the .NET assembly or the signed cabinet 
file. 

copying or transferring said copied 
first portion of said first protected 
information from said third secure 
container to said second secure 
container. 

When the second secure container is the 
signed .msi file and the third secure 
container is the signed .NET assembly, the 
.NET assembly is placed into the signed 
.msi file. 

When the second secure container is either 
the .NET assembly or the signed .msi file 
and the third secure container is the signed 
cabinet file, the signed cabinet file is placed 
into either the .NET assembly or the signed 
.msi file. 


87. A method as in claim 85 in which said 
copied first portion of said first protected 
information consists of the entirety of said 
first orotected information. 

The entire .NET component is copied. 


93. A method as in claim 85 in which 


said step of copying transferring said 
copied first portion of said first protected 
information from said third secure 
container to said second secure container 
further comprises storing said third secure 
container in said second secure container. 

When the third secure container is the 
signed .NET assembly, it is placed in the 
signed .msi file. 

When the third secure container is a signed 
cabinet file, it can be placed in either the 
.NET assembly and/or the signed .msi file. 


94. A method as in claim 85 further 
comprising: 


creating a fourth rule set. 

When the second rule set is declarative 
statement^ within the assembly's header. 

M 
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the fourth rule set is the conditional syntax 
statements) written by the .NET assembly 
developer arid placed into the signed .msi 
file. 

When the second rule set is the conditional 
syntax statement(s) written by the .NET 
assembly developer and placed into the 
signed .msi file, the fourth rale set is 
declarative statement(s) within the 
assembly's header or the set of declarative 
statements comprising the 
LicenseProviderAttribute in the .NET 
component. ; 


95. A method as in claim 94 further 
comprising: 


using said fourth rule set to govern at least 
one aspect of use of said copied first 
portion of said first protected information. 


If the fourth rule set is the .NET assembly 
developer's declarative statement(s) within 
the .NET assembly's header, it governs the 
use of the .NET component. 

If the fourth rule set is the conditional 
syntax statements of the .NET assembly 
developer's signed .msi file, it governs the 
offer/installation of the .NET component. 


n 
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85 (second alternate scenario for .NET) 


I A method comprising the following step s: 


7 creating a first secure container comprising 
J a first rule set and first protected 

8 1 information; 


10 

11 

12 

13 

14 
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Infringing products include the .NET 
Framework SDK, Microsoft Visual Studio 
■NET, the Microsoft Installer SDK, and 
products that include the Microsoft .NET 
CLR, and the Microsoft Installer 
technology. • 


I storing said first secure container in a first 
21 memory: 


creating a second secure container 
22 J comprising a second rule set; 


23 
24 
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storing said second secure container in a 
second memory: 


copying or transferring at least a first 
portion of said first protected information 
to said second secure container, said 
copying or iransferring step comprising: 


The first protected information is a .NET 
component. 

The first alternative for the first secure 
container is the signed and licensed .NET 
component. The first rule set is the set of 
declarative statements comprising the 
LicenseProviderAttribute in the .NET 
component. 

The second alternative for the first secure 
container is a (signed or unsigned) .NET 
component with license support contained 
within a cabinet file signed by the .NET 
assembly developer. The first rule set is 
the set of declarative statements comprising 
the LicenseProviderAttribute in the .NET 
component. 

The third alternative for the first secure 
container is a .NET component whose hash 
is included in the assembly header of a 
.NET assembly. The first rule set is the set 
of declarative statements comprising the 
LicenseProviderAttribute in the .NET 
component. 


The first secure container is stored at the 
NET assembly developer's location. 


The second secure container is the signed 
.msi file in which the .NET assembly 
developer packages its signed assembly. 
The second rule set is the conditional 
syntax statement(s) written by the .NET 
assembly developer and placed into the 
signed .msi file. 


The second secure container is stored at the 
.NET assembly developer's location. 


creating a third secure container 
comprising a third rule set: 


The .NET assembly developer places the 
.NET component into the third secure 
container, which is the signed .NET 
assembly. 


The third secure container is a signed .NET 
assembly and the third rule set is 
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declarative statement(s) within the 
assembly's header. . 


copying said first portion of said 
first protected information: 


Copying the .NET component to the .NET 
assembly. ] 


transferring said copied first portion 
of said first protected information to 
said third secure container, and 


Transferring the .NET component to the 
.NET assembly. 


copying or transferring said copied 
first portion of said first protected 
infonnation from said third secure 
container to said second secure 
container. 


When the second secure container is the 
signed .nisi file and the third secure 
container is the signed ;NET assembly, the* 
.NET assembly is placed into the signed 
.msi file. 


11. A method as in claim 85 in which said 
;opied first portion of said first protected 
nformation consists of the entirety of said 
Irst protected information. 


The entire .NET component is copied. 


)Q. A method as in claim 85 in which 


;aid first memory and said second memory 
Lre located at the same site. 


First and second memory is at the .NET 
assembly developer's location. 


>3. A method as in claim 85 in which 


aid step of copying transferring said 
opied first portion of said first protected 
nformation from said third secure 
ontainer to said second secure container 
urther comprises storing said third secure 
ontainer in said second secure container. 


When the third securie container is "the 
signed .NET assembly, it is placed in the 
signed .msi file. 
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96. A method comprising performing the 
following steps within a virtual distribution 
environment comprising one onmore 
electronic appliances and a first -secure 
container, said first secure container 
comprising a first control set and first 
protected information: 


A signed and licensed .NET component 
(first container) is part of a .NET assembly 
(second container), which is packaged in a 
signed .msi file (third container). 


using at least one control from said first 
control set to govern at least one aspect of 
use of said first protected information 
while said first protected information is 
:ontained within said first secure container 


The first secure container is a licensed and 
signed .NET component governed by the 
set of declarative statements comprising the 
LicenseProviderAttribute (one control). 


creating a second secure container 
comprising a second control set for 
governing at least one aspect of use of 
Drotected information contained within said 
second secure container: 


The second secure container is a .NET 
assembly, the protected information is the 
assembly and the second control set- is 
declarative statement(s) within the 
assembly's header. 


ncorporating a first portion of said first 
protected information in said second secure 
:ontainer, said first portion made up of 
;ome or all of said first protected 
nformation: 


Included in the .NET assembly is the .NET 
component. 


ising at least one control to govern at least 
>ne aspect of use of said first portion of 
aid first protected information while said 
irst portion is contained within said second 
ecure container: and . ' . 


The declarative statement(s) govern the use 
of the -NET component and the custom 
LicenseProvider class (first control set) 
controls the .NET component. 


ncorporating said second secure container 
ontaining said first portion of said first 
►rotected information within a third secure 
ontainer comprising a third control set. 


The third secure container is the signed 
.msi file in which the .NET assembly 
developer packages its assembly. The third 
control set is the conditional syntax 
statements written by the assembly 
developer and placed into the signed .msi 
file. 
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Infringement is based on Microsoft's Visual Studio 
.NET and/or the .NET Framework licensing tools (in 
the.NET Framework SDK) and/or Microsoft Installer 
SDK.. - 


A system for supporting electronic 
commerce including: 


means for creating a first secure control 
set at a first location; 


The first location is a .NET component developer's 
site. .. 
The first secure control set is the set of declarative 
statements comprising the LicenseProviderAttribute of 
a first .NET licensed component that provides for a 
design-time license to use the control. This attribute 
also specifies the type of license validation that occurs. 
The component is encapsulated in a signed .NET 
assembly 


means for creating a second secure 
control set at a second location; 


The second location is the .NET application 
developer's site where a .NET application comprising 
one or more assemblies is created. 

The second secure control set comprises the 
declarative statement(s) (including licensing 
statements, and code access security statements) of a 
signed .NET assembly using or calling the first .NET 
component. The control set can include a set of 
security permissions demanded by the .NET assembly 
containing the licensed component, whereby the 
pennissions are demanded of components that call the 
application components. The control set can also be 
extended by controls expressed as conditional syntax 
statements in a signed .msi file containing a click 
through end^user license (the end-user license 
scenario). 


neans for securely communicating said 
5rst secure control set from said first 
ocation to said second location; and 


The first .NET control set is securely communicated 
from the first location developer to the .NET solution 
provider by either being contained in a signed 
assembly, within a signed cabinet file or within a 
signed .msi file. 


neans at said second location for 
;ecurely integrating said first and 
;econd control sets to produce at least a 
hird control set comprising plural 
;lements together comprising an 
slectronic value chain extended 
igreement. 


At the second location, the solution developer uses the 
.NET runtime that includes the LicenseManager. 

Whenever a class (control or component) is 
instantiated (here, an instance of the first .NET 
licensed component), the license manager accesses the 
proper validation mechanism for the control or 
component. A value chain is created through the 
creation of a run-time license for use of the first .NET 
component in the context of use of the .NET 
application developed at the second location. The 
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license controls for the runtime license (derived from 
the design time license) are bound into the header of 
the .NET application assembly, along with the second 
control set 

The creation of runtime license controls is securely 
handled by Visual Studio.NET or the LC tool/ 
Runtime licenses are embedded into (and bound to) 
the executing assembly. The license control attribute 
included in the first .NET component is customized in 
the second location to express and require the runtime 
license. In a different scenario, the LC tool is used to 
create a ".licenses file" containing licenses for 
multiple components, including runtime licenses for 
components and classes created by the license 
provider. This .licenses file is embedded into the 
assembly. 

The third control set is an extended value chain 
agreement that comprises ihe runtime license controls* 
for the first .NET licensed class (that had been bound 
to the assembly), the declarative controls provided by 
the solution provider in the solution provider's 
assembly, and any runtime licenses for other 
components included by the solution provider in the 
solution provider's assembly, and any end user license 
agreement provided by the application provider. The 
controls are typically integrated into the header of the. 
.NET application assembly calling the first .NET 
licensed component. 

A further "end user licensing scenario" occurs when, 
at the second location, the application developer 
packages the application into a signed .msi file that 
includes conditional syntax statement controls that 
require that a user read and agree to an end user 
license agreement for the application and the 
embedded first component The third control set 
includes a plurality of elements that include the run- 
time licenses mentioned above, security permissions 
controls, EULA controls (a fourth control set), all 
securely bound into the signed .msi file. 


1 . A system as in claim 2 in which said 
rst location and said second location are 
sntained within a Virtual Distribution 
nvironment. 


The Microsoft .NET Framework provides a 
Virtual Distribution Environment. Here the 
nodes are the Common Language Runtime 
instances that interpret the controls 
contained within .NET assemblies (among 
other functions). 


9. A system as in claim 2 in which said 
rst secure control set includes required 


The licensing control in the first control set 
specifies the method required to validate 
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terms. 

1 the license. 1 

I 
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32. A system as in claim 2 in which said 
second secure control set includes required 
terms. 

The security permissions demanded (as 
described above) are required terms for 
execution of the application code elements. 

4 


5 
6 

n 
1 

8 

60. A system as in claim 2 in which said 
means for securely integrating 1 said first arid 
second control sets includes a fourth 
control set. 

In the scenario where the application 
assembly is distributed using a signed .msi 
file, the secure integration of the first and 
second control sets is enhanced by the 
tamper protection afforded by the signed 
.msi file. In the end user license scenario, a 
fourth control set consisting of conditional 
syntax statements is included in the .msi 
file. 

9 


in 

11 

130. A system as in claim 2 further 
including means for executing said third 
control set within a protected processing 
environment. 

The third control set is executed under the 
auspices of the CLR . 


13 

132. A system as in claim 130 in which 
said protected processing environment is 
located at a location other than said second 
location. 

The third control set is executed at an end- 
user site within the CLR. 

14 


15 
16 
17 

1 61 . A system as in claim 2 in which said 
third control set includes controls 
containing human-language terms 
corresponding to at least certain of the 
machine-executable controls contained in 
said third control set. 

In the end user license scenario, the third 
control set includes a fourth control set that 
requires that the human user agree with 
license terms displayed to the user. These 
human readable terms are referenced in the 
conditional syntax statement controls 
contained in the signed .msi file. 

18 
19 

1 62. A method as in claim 161 in which 
said human-language terms are contained 
in one or more data descriptor data 
structures. 

The .msi file is a data descriptor data 
structure. 

20 


21 

22 

1 70. A system as in claim 2 in which said 
means for creating a first secure control set . 
includes a protected processing 
environment. 

The creation of the first licensed 
component, including its licensed controls 
is carried out under the auspices of the 
CLR. 



23 
24 

171. A system as in claim 2 in which said 
means for creating a second secure control 
set includes a protected processing 
environment. 

The application design time environment 
and the creation of the .NET application is 
carried out under the auspices of the CLR. 

25 


26 

27 

172. A system as in claim 2 in which said 
means at said second location for securely 
integrating includes a protected processing 
environment 

The means for integrating the runtime 
license with the application controls is 
carried out under the auspices of the CLR. 



28 

329. A svstem as in claim 2 in which said 

VS.NET runs under Windows. 1 


11 
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means for creating a first secure control set 
includes an operating system based on or 
compatible with Microsoft Windows. 
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330. A system as in claim 2 in which said 
means for creating a second secure control 
set includes an operating system based on 
or compatible with Microsoft Windows. 


VS.NET runs under Windows. 


33 1 . A system as in claim 2 in which said 
means at said second location for securely 
integrating said first and second control 
sets includes an operating system based on 
or compatible with Microsoft Windows. 


VS.NET runs under Windows. 


346. A system as in claim 2 further 
comprising means by which said third 
control set governs the execution of at least 
one load module. 


The third control set in the scenario 
described in the claim map for claim 2 
governs a portable .NET executable 
designed to be loaded into the CLR * 
environment fa CLR host). 


347. A system as in claim 2 farther 
comprising means by which said third 
control set governs the execution of at least 
I one method. 


The third control set in the scenario 
described in the claim map for claim 2 
governs a .NET executable. This 
executable contains one or more methods. 


349. A system as in claim 2 further 
comprising means by which said third 
control set governs the execution of at least 
one procedure. 


The third control set in the scenario 
described in the claim map for claim 2 
governs a .NET executable. This 
executable contains one or more 
procedures. 
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* ;GLA1M LANGUAGE > 


Ir^feGEMM^QKINFRINGEMENT 


4«. 


A method for narrowcasting selected 
digital information to specified 
recipients, including: 


Infringing products include Microsoft SMS 
(Systems Management Server) 2.0 and 
subsequent versions. « ■ 


a) at a receiving appliance, receiving 
selected digital information from a 
sending appliance remote from the 
receiving appliance, 


The receiving appliance is the client (e.g., end 
user computer in an Enterprise setting) 
receiving digital information (packages and/or 
advertisement files) from the sending 
appliance^ the centralized SMS database via a 
Client Access Point and/or Distribution Point 
set up on a server. 


the receiving appliance having a 
secure node and being associated 
with a specified recipient; 


The "node" is "secure" as a result of SMS 
security, as well as how it identifies and selects 
clients. 

The "specified recipient" is the result of the 
collection identifying a specific client that 
meets the criteria for a package or 
advertisement. 


i) the digital information having 
been selected at least in part based on 
the digital information's membership in 
a first class, wherein the first class 
membership was determined at least in 
part using rights management 
information; and 


The digital information is a software package . 
or advertisement. The "first class membership 
was determined in part using rights 
management information 9 ' reads on creating 
software packages (or advertisements) based 
on attributes of the software. 


ii) the specified recipient having 
been selected at least in part based on 
membership in a second class, wherein 
the second class membership was 
determined at least in part on the basis 
of information derived from the 
specified recipient's creation, use of, or 
interaction with rights management 
information: and 


The "specified recipient" is the client selected 
to receive a package or advertisement. That 
recipient is chosen based on a collection rule, 
or on the recipient's possession of a license. 


b) the specified recipient using the 
receiving appliance to access the 
received selected digital information in 
accordance with rules and controls, 
associated with the selected digital 
information. . 


The receiving appliance is the client computer. 
The SMS agents on the client computer 
receive, evaluate and take the appropriate 
action based on rules and controls governing 
the package and/or advertisement (i.e. the 
selected digital information). 


the rules and controls being enforced 


Rules arid c&nirols are enforced by Agents on 
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the client (the secure node) 
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59. The method of claim 48 wherein 
said received selected digital 
information is at least in part 'event 
information. '• 


Event information includes SMS event 
information, including Scheduling Classes 


63. The method of claim 48 wherein 
said received selected digital 
information is at least in part executable 
software. 


All SMS packages must include a minimum of 
one program. 


70. The method of claim 48 wherein 
said rules and controls at least in part 
govern usage audit record creation. 


A control governs whether a MIF 
(management information file) is sent back to 
the SMS db after installation is done to report 
on the success or failure of the installation. 


89. The method of claim 48 wherein 
said receiving appliance is a personal 
computer. 


The primary purpose of SMS is to manage 
software on personal computers throughout the 
Enterprise. ■__ 
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48. 


Infringing products include Windows' 
Media Player and Windows Media Rights 
Manager . 


A method for narrowcasting selected 
digital information to specified recipients, 
including: 


This claim pertains to Windows Media 
Player with Individualized DRM Client and 
Windows Media Rights Manager used in 
the context of a narrowcast pay-per-view 
(hear) media distribution service.,* 
simulcast and/or subscription services. 


a) at a receiving appliance, receiving 
■elected digital information from a sending 
ippliance remote from the receiving 
ippliance, the receiving appliance having a 
;ecure node and being associated with a 
;pecified recipient 


Receiving appliance is a user's PC with 
individualized DRM client (secure node). 
Specified recipient is a user using the 
specific individualized DRM client to 
access and render narrowcast pay-per-view 
media, simulcast and/or subscription 
services for which the user acquires a 
license. 


i) the digital information having been 
elected at least in part based on the digital 
nfonnation's membership in a first class, 
vherein the first class membership was 
letermined at least in part using rights 
nanagement information; and 


The digital information is media that is 
narrowcast to licensed recipients. These 
narrowcast streams are licensed to users 
who have acquired licenses and whose PCs 
(appliances) support WMPs that have 
individualized DRM clients. This attribute 
is included in the signed WMA file header 
and is used in the process of acquiring 
licenses for access to the media. Media that 
are licensed to the recipient have their 
licenses bound to the recipient's 
Individualization module. 


ii) the specified recipient having been 
elected at least in part based on 
lembership in a second class, wherein the 
econd class membership was determined 
t least in part on the basis of information 
erived from the specified recipient's 
reation, use of, or interaction with rights 
lanagement information; and 


The recipient is selected for this content 
based on the fact that the recipient is a 
member of the class of recipients who have 
a license for the narrowcast media and 
whose devices support WMP and 
individualized DRM clients. The 
recipient's machine must indicate support 
for individualization in challenges that are 
sent as part of requests for media in this 
narrowcast class. , 


o) the specified recipient using the 
xeiving appliance to access the received 
sleeted digital information in accordance 
,'ith rules and controls, associated with the 
sleeted digital information, the rules and 
ontrols being enforced by the receiving 
ppliance secure node. • 


Recipient's machine uses WMP and the 
individualized DRM client to access the 
narrowcast media in accordance with all 
rules associated with the media and 
contained in the media license - in 
particular, requirements that 
individualization be supported. 
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61. The method of claim 48 wherein said 
received selected digital information is at 
least in part entertainment information. 

The digital information is Windows Media, 
which encodes audio/visual entertainment 
content. 



62 'The method of claim 61 wherein said 
entertainment information is at least in nart 
music information. 

RpflHs on narrnwrast Winrinws N4*v1iji Filps 
that are music or audio/visual 

* 



67. The method of claim 48 wherein said 

J UJCo OJlvJ dJJJUUio al iCaoL 111 Udll UjC U1K1U11 

Pi*rtifif*Atp mfnrmjitinri 

Is^l UlJlrulV JJUU1 JUtllJVJll. 

The license contains a digital certificate. 
i nc jL/j\jvj cucni ubcb mc ccruiicaie in uie 
jiucjioc iu vein j uiib Mgiiaiuic <uju iu vcniy 
that the header has not been tampered with. 



.72. The method of claim 48. wherein said 
rules and controls in part specifying at least 
one clearinghouse acceptable to 
ngnisnojoers. 

The signed .header contains at least .one 
URL that indicates to the Windows Media 
Rights Manager the license clearinghouse 
to be used in acquiring licenses. 



75. The method of claim 72 wherein said at 
least one acceptable clearinghouse is a 
rights and permissions clearinghouse. 

This clearinghouse is a license 
clearinghouse responsible for mapping 
rights and permissions onto requested 
content or narrowcasts and binding them to 
the requesting client environment or user of 
this environment. 



89. The method of claim 48 wherein said 
receiving appliance is a personal computer. 

Windows Media Player and the 
Individualized DRM client run on a 
personal computer. 



• '■!! 
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91 

Infringing products include Windows 
Media Player and Windows Media Rights. 
Manager 

A method for securely narrowcasting 
selected digital information to specified . 
recipients including: 

This claim pertains to Windows Media 
Player with Individualized.DRM Client and 
Windows Media Rights Manager used in 
the context of a narrowcast simulcast, pay- 
per-view (hear) media distribution service, 
and/or subscription services. The content 
is delivered in a Protected Windows Media 
File. 

(a) receiving selected digital information in 
a secure container at a receiving appliance 
remote from a sending appliance, the 
receiving appliance having a secure node, 
the receiving appliance being associated 
with a receiving entitv 

Narrowcast content is received in a 
Protected Windows Media File. Receiving 
appliance is user's PC with individualized 
DRM client (secure node). 

(i) the digital information having 
been selected at least in part based 
on the digital information's 
membership in a first class, 

The digital information is media that is 
narrowcast to licensed recipients (for 
example, a sold-out concert is narrowcast 
on the Internet to "the class of" licensed (or 
ticketed) viewers). 

(ii) the first class membership 
having been determined at least in 
part using rights management 
information 

These narrowcast streams are licensed to 
users who have acquired licenses and 
whose PCs (appliances) support WMPs 
that have individualized DRM clients. This 
attribute is included in the signed WMA 
file header and is used in the process of 
acquiring licenses for access to the media. 
Media that are licensed to the recipient 
have their licenses bound to the recipient's 
individualization module. 

(b) the receiving entity having been 
selected at least in part based on said 
receiving entity's membership in a second 
class. 

The recipient is selected for this content 
based on the fact that the recipient is a 
member of the class of recipients who has a 
license for the narrowcast media. 

(i) the second class membership 
having been determined at least in 
part on the basis of information 
derived from the recipient entity s 
creation, use of, or interaction with 
rights management information 

The recipient class is determined by the 
license bound to the user's device that 
supports WMP and individualized DRM 
clients. The recipient s machine must 
indicate support for individualization in 
challenges that are sent as part of requests 
for media in this narrowcast class. 

(c) receiving at the receiving appliance 
rules and controls in a secure container. 

Receives a protected Windows Media File 

(i) the rules and controls having 
! been associated with the selected 
j digital information; and 

Receives a license that is bound to the file 
as well as to the specific DRM client 
individualization information. 

(d) using at the receiving appliance the 
selected digital information in accordance 

Recipient's machine uses WMP and the 
individualized DRM client to access the 
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with the rules and controls, 


narrowcast media in accordance with all 
rules associated with the media and 
contained in the media license - in 
particular, requirements that 
individualization be supported. 


(i) ihe rules and controls being • 
enforced by the receiving appliance 
secure node. ■ 


The WMP and DRM client enforce the ' 
rules embedded in the Protected Windows 
Media File License. * ■ 


104. The method of claim 91 wherein said 
received selected digital information 
includes entertainment information. 


The digital information is Windows Media, 
which encodes audio/visual entertainment 
content 
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109. The method of claim 91 wherein said 
rules and controls at least in part use digital 
certificate information. 


The license contains a digital certificate. 
The DRM client uses the certificate in the 
license to verify this signature and to verify 
that the header has not been tampered with. 


114. The method of claim 91 wherein said 
rules and controls specify at least one 
clearinghouse acceptable to rightsholders. 


The signed header contains at least orie 
URL that indicates to the Windows Media 
Rights Manager the license clearinghouse 
to be used in acquiring licenses. 


117. The method of claim 1 14 wherein said 
I at least one acceptable clearinghouse is a 
rights and peimissions clearinghouse. 


This clearinghouse is a license 
clearinghouse responsible for mapping 
rights and permissions onto requested 
content or narrowcasts and binding them to 
the requesting client environment or user of 
this environment. ' 


131. The method of claim 91 wherein said 
receiving appliance is a personal computer. 


Windows Media Player and the 
individualized DRM client run on a 
personal computer. • 
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1; 


Products infringing: Microsoft Visual Studio 
.NET, .NET License Compiler, .NET 
Framework SDK, and .NET Common 
Language Runtime _ 


A method including 


A method for producing a third .NET 
component (application) that incorporates first 
and second .NET component whose 
distribution is license controlled. 


creating a first secure container including a 
first governed item and having associated a 
first control; 


The first secure container is a first signed 
.NET component that includes a license 
control. The governed item is the .NET 
component.- 

The first control is the set of declarative 
statements comprising the 
LicenseProviderAttribute of a first .NET 
licensed component that provides for a design- 
time license to use the control. This attribute 
also specifies the type of license validation that 
occurs. 


The second secure container is the second 
signed .NET component that includes a license 
control. The governed item is the .NET 
component. 

The second control is the set of declarative 
statements comprising the 
LicenseProviderAttribute of a second .NET 
licensed component that provides for a design- 
time license to use the control. This attribute 
also specifies the type of license validation that 
occurs. 


seating a second secure container including a 
lecond governed item and having associated a 
econd control; 


ransferring the first secure container from a 
irst location to a second location; 


The creator distributes a signed and licensed 
.NET. component. 

An application developer at a second location 
downloads a first .NET component for 
inclusion into an application. 


ransferring the second secure container from a 
bird location to the second location; 


A creator distributes a signed and licensed 
.NET component from a different location. 

Application developer downloads a second 
.NET component for inclusion into an 
application. 
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at the second location, obtaining access to at 
least a portion of the first governed item, the. 
access being governed at least in part by the 
first control; 


At the second location, the application 
developer uses the .NET runtime that includes 
the LicenseManager to access a first governed 
item. . 

Whatever a class (control or component) is 
instantiated (here, an instance of the first .NET 
licensed component), the license manager 
accesses the proper validation mechanism for 
the control or component. 

The first control comprises the declarative 
statement(s) (including licensing statements, 
and code access security statements) of tiie first 
.NET component 


at the second location, obtaining access to at 
least a portion of the second governed item, the 
access being governed at least in part by the 
second control; 


At the second location, the application " 
developer uses the .NET runtime that includes 
the LicenseManager to access a second 
governed item. 

Whenever a class (control or component) is 
instantiated (here, an instance of the second 
.NET licensed component), the license 
manager accesses the proper validation 
mechanism for the control or component. 
The second control comprises the declarative 
statement(s) (including licensing statements, 
and code access security statements) of the 
second .NET component. ^_ 


it the second location, creating a third secure 
container including at least a portion of the first 
jovemed item and at least a portion of the 
second governed item and having associated at 
east one control, the creation being governed 
it least in part by the first control and the 
;econd control. 


At the second location, the application 
developer uses the .NET runtime that includes 
the LicenseManager to access a first governed 
item and second governed item to construct an 
application, the third secure container. 

Creation governance is accomplished by 
invoking the .NET 'runtime to access the first 
governed item and the second governed item. 

Whenever a class (control or component) is 
instantiated the license manager accesses the 
proper validation mechanism for the control or 
component. 

The portions of the first governed item and 
second governed item that are being included 
in the third secure container will typically 
include the governed, items themselves, ie. the 
.NET components. 

The associated control in this case is the 
LicenseProviderAtiribuie, created and inserted 
into the application. 
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